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Features 


1.0 Features 


Note: Change bars indicate document changes between 
the AIC-33C93B and AIC-33C93C Data Sheets. 


¢ All functions and timings are current with the proposed 
SCSI-3 Parallel Interface standard X3T9.2/91-010R8, 
November 10, 1992. 


¢ Implements full 8-bit single-ended SCSI bus features: 
arbitration, disconnect, reconnect, parity generation and 
checking on both data ports, soft reset, and synchronous 
data transfers. 


¢ Includes 48 mA drivers for direct connection to the SCSI 
bus. 
¢ Data bus pins (SDB[0..7] and SDP) utilize active- 
negation drivers for improved noise immunity. 


¢ REQ and ACK pins have 57mA active-negation 
drivers to accommodate high-current terminators. 


¢ Includes a high-performance SCSI bus receiver to afford 
800 mV (typ) of hysteresis to reject most reflection- 
induced noise. 


¢ Operates in both initiator and target roles. 


¢ Operates as both a SCAM level one master or a SCAM 
level two slave. 


¢ Synchronous offset selectable from one to twelve bytes. 
¢ Programmable time-out for selection and reselection. 


¢«  SCSI-2 features: 
¢ Synchronous transfer rates up to 10 Mbytes/s for Fast 


SCSI transfers; up to 5 Mbytes/s for standard SCSI 
transfers. 


¢  Select-and-Transfer, Reselect-and-Transfer, and Wait- 
for-Select-and-Receive commands support queue tag 
messages and target routine identify messages. 


¢ “Combination” commands greatly reduce interrupt- 
handling responsibilities. 


* Compatible with most microprocessors through an 8-bit 
data bus; supports both multiplexed and non-multiplexed 
address/data bus systems. Host bus data parity checking 
and generation is an optional feature. 


¢ Burst data transfers of up to 4096 bytes. 


¢ Data transfer options include polled I/O, single-byte DMA, 
burst (multibyte) DMA, or direct bus access (WD bus) 
transfers. 
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General Description 


¢ Improved host interface timings to support faster CPUs. 
¢ Single +5 V supply. 
¢ Available in 44-pin chip carrier. 


¢ Low-power CMOS design. 


2.0 Description 


2.1 General Description 


The AIC-33C93C, a CMOS/VLSI device, operates from a 
single 5 Volt supply and is available in a 44-pin chip carrier. 
All inputs and outputs are TTL compatible. 


The AIC-33C93C is intended for use in systems which 
interface to the Small Computer System Interface (SCSI) Bus. 
The AIC-33C93C can operate in both the initiator (typically, a 
host computer system) and the target (typically, a peripheral 
device) SCSI bus roles. 


When used in the host system, the AIC-33C93C interfaces to 
both the host bus and the SCSI bus. To perform a SCSI 
operation, the host processor issues a command to the AIC- 
33C93C to select the desired target. The AIC-33C93C then 
arbitrates for the SCSI bus and selects the peripheral unit. If it 
fails to get the bus because of a device with higher priority, it 
continues trying and notifies the host when it has succeeded 
by generating an interrupt. At this point, the AIC-33C93C is. 
operating in the initiator role. When the peripheral requests a 
SCSI command from the host, the AIC-33C93C interrupts the 
host. The host responds to this interrupt by issuing a Transfer 
Info command and supplying SCSI command bytes to the 
AIC-33C93C. The AIC-33C93C transfers the SCSI command 
to the peripheral and then waits for the next bus phase request. 
This process continues until all SCSI information including 
data, status, and messages have been transferred. 


The AIC-33C93C also offers high-level Select-and-Transfer 
commands which eliminate the interrupt handling otherwise 
required between each SCSI bus phase. 


When the AIC-33C93C is used in a peripheral system, the 
AIC-33C93C operates primarily in a target role. It interfaces 
with a local processor and the SCSI bus in this environment 
just as it does when used in a host adapter. The target-role 
command set enables the AIC-33C93C to request each SCSI 
bus phase individually or to sequence the SCSI bus phases 
automatically. 


Differences between the AIC-33C93A, AIC-33C93B, and AIC-33C93C 


The AIC-33C93C has an internal microcontroller, a register | ° 


task file, and SCSI interface logic. This architecture supports 
both tight control of the protocol for non-standard SCSI 
implementations, as well as a hands-free mode for standard 
SCSI applications. 


2.2 Differences between the AIC-33C93A, AIC- 
33C93B, and AIC-33C93C 


The AIC-33C93B delivers the same functionality as the AIC- 
33C93A and incorporates several enhancements to support 
SCSI-2 and improve system operation and reliability. In most 
applications, unless configured with the REALLY 
ADVANCED FEATURES bit in the OWN ID register set, the 
AIC-33C93B is backwardly compatible to the AIC-33C93A 
and hence may replace the AIC-33C93A with no 
modifications to hardware or firmware. 


The AIC-33C93C, except for lacking the Translate Address 
command, is a drop-in replacement for the AIC-33C93B. In 
addition, it provides commands to implement the SCSI 
automatic configuration (SCAM) protocol. 


The AIC-33C93B and AIC-33C93C products include several 
improvements to the AIC-33C93A design intended to bolster 
system performance and reliability: 


¢ To reduce overhead during polled I/O transfers, the AIC- 
33C93B/C reports the FIFO status via the FIFO 
FULL/EMPTY bit in the AUXILIARY STATUS register. 
As its name suggests, this bit reflects the full or empty state 
of the FIFO depending on the direction of the transfer. If 
the host is writing data to the FIFO, the AIC-33C93C sets 
this bit when the FIFO is empty, indicating that the host 
may write up to twelve bytes to the FIFO without having to 
poll the DATA BUFFER READY bit before writing each 
byte. Similarly, when the host is reading data from the 
FIFO, the AIC-33C93B/C sets this bit when the FIFO is 
full, indicating that the host may read the DATA register 
twelve times without polling DATA BUFFER READY 
before each read. 


¢ To support Fast SCSI transfers without increasing the 
signal reflection problem, the REQ, ACK, SDP, and SCSI 
data pins utilize Active Negation Drivers, instead of the 

~ open-drain drivers that the AIC-33C93A uses. These 





drivers actively pull signals up to a high (negation) level — 


instead of relying on the terminators to do so and allow 
better control of rise times and of the negation level. Active 
negation drivers, moreover, can source more current to the 
bus to help the terminators reduce bus reflections. 


Description 


To improve system reliability, the AIC-33C93B/C design 
expands the group of features enabled by configuring the 
device with the REALLY ADVANCED FEATURES bit 
set. In addition to features shared with the AIC-33C93A, 
the AIC-33C93B/C detects and reports violations of the 
data transfer protocol and unexpected disconnects from the 
SCSI bus when operating as a target. 


] The AIC-33C93B and AIC-33C93C also possess various 


enhancements designed to support SCSI-2: 


¢ The combination commands Select-and-Transfer, 
Reselect-and-Transfer, and Wait-for-Select-and-Receive 
optionally send or receive Queue-tag messages at 
appropriate points in the SCSI phase sequence. The 
processor via two bits in the DESTINATION ID register 
and by way of the QUEUE TAG register supplies 
information which the first two commands use to generate 
and check these messages. Wait-for-Select-and-Receive, 
through the same locations, reports the type of Queue-tag 
message received, including whether or not the initiator 
sent a message, and the actual queue tag. 


¢ These commands also support the LUNTAR bit in the 
Identify message. By setting the corresponding bit in the 
TARGET LUN register, the host enables the Select-and- 
Transfer and Reselect-and-Transfer commands to send a 
target routine Identify message. In the case of Select-and- 
Transfer, setting this bit also enables the AIC-33C93B/C to 
accept automatically an Identify message with the 
LUNTAR bit set. The host also has the option to let the 
Wait-for-Select-and-Receive command receive a target 
routine Identify message and proceed to the next phase or 
to interrupt the host so that it may reject the message when 
the application does not support target routines. 


¢ The AIC-33C93B/C can perform Fast SCSI transfers. 
When the AIC-33C93B/C has an input clock between 16 
MHz and 20 MHz, by controlling the FAST SCSI SELECT 
bit in the SYNCHRONOUS TRANSFER register, the host 
can select between normal synchronous transfers which 
reach a maximum transfer rate of 5 MB/s and Fast 
synchronous transfers with a peak rate of 10 MB/s on both 
the SCSI and host DMA interfaces. 


‘| The AIC-33C93C, to support the SCAM protocol, provides a 


set of new commands consisting of both high-level and low- 
level commands. This combination simplifies implementation 
of SCAM features but allows flexibility for non-standard 
applications. 
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AIC-33C93C Pinout Differences between the AIC-33C93A, AIC-33C93B, and AIC-33C93C 


¢ The Enable SCAM Tolerant Timings command modifies 3.0 AIC-33C93C Pinout 
the interpretation of the Time-out Period register so that the 


maximum selection time-out is four milliseconds and 
delays the response to selection so that the AIC-33C93C 
responds only after the selection phase has persisted for at. 
least four milliseconds. These timings allow a SCAM 
device to identify other SCAM devices on the bus. 


44-pin Chip Carrier 


¢ The Enable SCAM Selection command allows the AIC- 


33C93C to respond to a SCAM selection. MR SDP 
ATIN ALE 
¢ The SCAM Select command allows the AIC-33C93C to ~ ACK RE 
SCAM select another SCAM device. REQ WE 
vcc CS 
e The SCAM Transfer command causes the AIC-33C93C to NC AIC-33C93C GND 
perform a SCAM transfer cycle. VO NC 
MSG AO 
« The Read SCSI Bus command allows the processor to GND D7 
sample the signals on the SCSI bus for diagnostic purposes c/D D6 
or for implementing the SCAM protocol using low-level BSY DS 


commands. 


¢ The Set Phase command provides a means for the 
processor to set the phase lines. 





¢ The Set Data command allows the processor to place a 
value onto the SCSI data bus. NOTE: PINS IN PARENTHESES ARE FOR TEST 
PURPOSES ONLY AND SHOULD BE _ LEFT 
UNCONNECTED FOR NORMAL CHIP OPERATION. 
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Processor/DMA Interface 


4.0 Pin Descriptions 


4.1 Processor/DMA Interface 


All I/O pins have tri-state push-pull drivers unless otherwise 
noted. 


Abbreviation: PWO = Pulsed Wired oR! 


Table 4-1 CPU/ DMA side Pins 


8-20 MHz square wave clock. 


MR Master Reset is an active-low input 
which causes the AIC-33C93C to 
al 














enter an idle state and release all 
SCSI signals. 


Interrupt Request to the external 
microprocessor indicates a 
command completion/termination or 
a need to service the SCSI interface. 
Reading the SCSI STATUS register 
clears this bit. 





























Read Enable is an active-low input 
used with CS to read a register or 
with DACK to access the DATA 
register in DMA mode. In AIC- Bus 
mode, it is an output used to read 
data from a sector buffer. 


Write Enable is an active-low input 
used with CS to write a register or 
with DACK to access the DATA 
register in DMA mode. In AIC- Bus 
mode, it is an output used to write 
data to a sector buffer. 





Chip Select is an active-low input 
which qualifies RE and WE when 
accessing a register. This signal 
must be inactive during a DMA 
cycle (DACK active in DMA and 


AIC- Bus mode). 


Pin Descriptions 


Table 4-1 CPU/DMaA side Pins (Continued) 


Address pin AO is used to access the 
internal registers for non- 
multiplexed address/data busses. 
The address of the desired register is 
loaded into the ADDRESS register 
during a write cycle with AO=0. The 
selected register is then accessed 
when AO=1. See the description of 
the ADDRESS register for a 
complete discussion of direct and 
indirect addressing. 


Address Latch Enable is used for 
multiplexed address/data busses to 
load the address of the desired AIC- 
33C93C register from the data bus. 
For indirect addressing, the ALE pin 
should be grounded. See the 


description of the ADDRESS 
register for a complete discussion of 
direct and indirect addressing. 


DMA Acknowledge is an active-low 
input used for interfacing to an 
external DMA controller (e.g. 
8237). When DACK is low, all bus 
transfers are to or from the DATA 
register regardless of the contents of 
the ADDRESS register. In AIC- Bus 
mode, this pin, an open-drain 
output, functions as a RAM Chip 
Select to the sector buffer. RE and 
WE are outputs when RCS is active. 
Regardless of the host DMA mode 
selected, this pin should be pulled 
via external circuitry (e.g. a pull-up 
resistor) to an inactive state and 
should not be left floating. 





| Burst DMA mode orRCSactivein [ 


1. A Pulsed Wired OR driver actively drives during the 
signal rise, then turns off the pull-up device to 
become an open drain driver. An external pull-up is 
required but may be a large value (~ 10K) 
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Pin Descriptions SCSI Interface 


Table 4-1 CPU/DMaA side Pins (Continued) Table 4-1 SCSI Interface Pins (Continued) 


DRO or or Tyo. | Data Request is an active-low output 

DRQ Wo when used for interfacing to an 
external DMA controller and an 
active-high input when in AIC- Bus 
mode. In the first case, DRQ and 
DACK form the handshake for the 
DMA data transfers. In Burst mode, 
DRQ remains low so long as there is 
data to transfer; in Single-byte DMA 
mode, DRQ toggles for each byte. 
Since this pin is an open drain 
output, a pull-up resistor may be 
required when operating in these 
modes. In AIC- Bus mode, this pin 
becomes the DRQ input. A high 
level on this pin enables the AIC- 
33C93C to perform burst transfers; a 
low level inhibits transfers by 
releasing RCS and disabling the RE 
and WE outputs. 


Data Parity is used only for 
checking and generating parity 
during data transfers. 









WO | AG is an-ontout in theinidatorrele | is an output in the initiator role 
and an input in the target role. It 
indicates an acknowledgment of a 
data transfer. 












MSG is an input in the initiator role 
and an output in the target role. The 
target asserts this signal when 
requesting message information. 







C/D is an input in the initiator role 
and an output in the target role. It 
specifies whether CONTROL or 
DATA information is on the SCSI 
data bus. 








1/O is an input in the initiator role 






and an output in the target role. It 
controls the direction of data 
movement on the SCSI data bus 
with respect to an initiator. 










BSY is asserted when the AIC- 
4.2 SCSI Interface 33C93C is attempting to arbitrate 
for the SCSI bus or when connected 


All pins are bidirectional, and except as noted, they all have as a target. 


open-drain output drivers. SEL is asserted when the AIC- 


33C93C is attempting to select or 


Abbreviation: AND = Active Negation Driver reccleceanother SCSI device 





| Table 4-1 SCSI Interface Pins 


ATIN is an output in the initiator role 
and an input in the target role. Its 
assertion indicates the ATTENTION 
condition. 


REQ is an input in the initiator role 
and an output in the target role. Its 
assertion indicates the target’s 
request for a transfer. 
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SCSI Interface AIC-33C93C Block Diagram 


| 5.0 AIC-33C93C Block Diagram 





cs 
Reoi Fil Processor AO 
egister File interhace ALE 
INTRQ 
BSY Bee RE 
ie Arbitration PLA Microcontroller WE 
SEL D[7:0] 
SD[7:0] 
SDP 
REQ 
ACK Host DMA PRO 
MSG SCSI REQ/ACK State Machine DP 
CD State Machine Transfer Counter 
YO _ 
AIN 
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AIC-33C93C Registers 


| 6.0 AIC-33C93C Registers 


6.1 Register Map 


[ao [Asie [Rw | __RepberName 

Po | | 8 [Anilay Sater 

0 | xx | W | AddressRegister | AddressRegister, Register 

fe [er leserees 
CDB Size Register 

| 1 | Ol | RAW | ControlRegister | Control Register | Register 

| 1 | 02 | RAW | Timeout Period Register | | Timeout Period Register | Period Register 

Te [setae 
SCSI Control Bus Register 

ae har Gal CDB2 Register or 
SCSI Data Register 

Pi [oe [ww [eves 

Pe [os [aw [copnense 

pif [Rar [coer meer 

Poe [aw [econo nese 

ed 

Destination ID Register 
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Register Map 


Source ID Register 
TT [at | e_| Sct status Register 





NOTES: 


1) All unused bits of a defined register are reserved and must 
be zero. 


2) Reading an undefined or unavailable register results in an 
all-ones data bus output. 


3) Register addresses are determined by the ADDRESS 
register bits AR4 through ARO. 


4) When using a multiplexed address/data bus with ALE, the 
AO pin is ignored, and the ADDRESS register is loaded 
with ALE. In this mode, the AUXILIARY STATUS 
register is mapped at 1F hex. 


6.2 Register Descriptions 
6.2.1 Auxiliary Status Register 


The AUXILIARY STATUS register, a read-only register, 
contains general status information not directly associated 
with an interrupt condition. The host may access the 
AUXILIARY STATUS register at any time except during 
DMA accesses, i.e. DACK asserted in DMA/Burst mode or 





RCS asserted in WD Bus mode. 


Table 6-1 Auxiliary Status Register 


BT [wi [Bie [BRA [Bie [BHD [BACT Bie o 
par [ier [asy | or [0 [re | Pe [DAR 


BitO DBR 











DATA BUFFER READY indicates to the 
processor whether or not the DATA register 
is available for reading or writing. During a 
Send command or a Transfer Info command 
which transmits data over the SCSI bus, the 
AIC-33C93C sets this bit when ready to 
take a byte from the host; it resets this bit 
when the processor writes the byte to the 


Register Descriptions 


Bit 1 


Bit 2 


Bit 4 


Bit 5 


Bit 6 


PE 


CIP 


BSY 


LCI 


DATA register. During a Receive command 
or a Transfer Info command which receives 
data over the SCSI bus, the AIC-33C93C 
sets DATA BUFFER READY when it 
receives a byte and resets the bit when the 
processor reads the byte from the DATA 
register. 


PARITY ERROR status indicates that the 
AIC-33C93C received a byte with even 
parity during a transfer. SCSI parity 
checking is always enabled; host parity 
checking is enabled via the ENABLE 


HOST PARITY bit in the OWN ID register. . 


Detection of a parity error will set this bit 
regardless of the state of the HALT on 
HOST PARITY ERROR or HALT on SCSI 
PARITY ERROR bits in the CONTROL 
register. Issuing a command clears this bit. 


FIFO FULL/EMPTY indicates when the 
FIFO is full or empty depending on the 
direction of the transfer. (see 6.2.18) 


COMMAND IN PROGRESS indicates that 
the AIC-33C93C is interpreting the last 
command entered into the COMMAND 
register. The processor can access the 
COMMAND register only when this bit is 
reset. 


BUSY indicates that a command is 
currently executing. When this bit is set, the 
host has access to the COMMAND register 
if COMMAND IN PROGRESS is reset, the 
DATA register if DATA BUFFER READY 
is set, and the AUXILIARY STATUS 
register, but it can not access any other 
registers. 


LAST COMMAND IGNORED indicates 
that the AIC-33C93C ignored a command 
because the host issued it just prior to or 
concurrent with a pending interrupt. 


INTERRUPT PENDING reflects the state 


of the INTRQ pin. When set, the host 
should read the SCSI STATUS register to 
clear INTRQ prior to issuing any 
commands. 


—«Bit3 | 
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6.2.2 Address Register 


The ADDRESS register, a 5-bit write-only register, holds the 
address of the register to be accessed. Registers in the AIC- 
33C93C may be accessed in one of two ways: 


¢ Direct addressing (multiplexed address/data busses). In 
this mode, the falling edge of the ALE signal latches the 
contents of the host data bus into the ADDRESS register. 
The CS and WE or RE signals typically follow to access 
the selected register. When using direct addressing, the AO 
pin should be connected to ground, and the AUXILIARY 
STATUS register is located at address 1F hex. 


¢ Indirect addressing (separate address/data busses). This 
method, enabled by tying ALE to ground, requires two 
separate cycles for a register access. The first cycle loads 
the desired address into the ADDRESS register by writing 
to the AIC-33C93C with AO=0. The second cycle, with 
AO=1, then reads or writes the selected register. Every 
cycle with AO=1 increments the ADDRESS register except 
when accessing the DATA or COMMAND registers. The 
AUXILIARY STATUS register is accessed by performing 
aread with A0=0. 


6.2.3 Own ID Register 


The OWN ID register stores information which the Soft Reset 
command uses to configure the device. Following a hardware 
reset and before issuing any other command, the host must 
initialize this register and issue the Reset command to set the 
clock divisor and the SCSI bus ID of the device, to enable 
various sets of features, and to enable host bus parity 
checking. 


Table 6-2. Own ID Register 
BR? [wig [Bie [BA [BES [BH | BHT [EO 
SCSI ID bits 0-2 set the SCSI bus ID that the 


AIC-33C93C uses during arbitration, 
selection, and reselection. 











Bits 0-2 [Dn 


ENABLE ADVANCED FEATURES, when 
set, enables the set of functions described in 
section 7.5. 


Bit4 EHP ENABLE HOST PARITY enables odd 


parity checking on the host bus. The 
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PARITY ERROR bit in the AUXILIARY 
STATUS register will then also indicate 
parity errors detected on the host bus, and 
the HALT on HOST PARITY ERROR bit in 
the CONTROL register will have effect 
during transfers. When host parity is 
disabled, the PARITY ERROR bit is not set 
when a parity error occurs on the host bus, 
and the HALT on HOST PARITY ERROR 
bit must be set to zero. NOTE: Parity is 
always generated on the host data parity bit 
(DP), regardless of the state of this control 


bit. 

BitS RAF REALLY ADVANCED FEATURES, when 
set, enables the features described in section 
7.6. 

Bits 6-7 FSn FREQUENCY SELECT 0-1 choose the 


divisor that is applied to the input clock. 
The divided clock is used for data transfer 
timing and for SCSI bus arbitration timing. 
The table below shows input clock 
frequency ranges and the corresponding 
divisors. An incorrect divisor for the input 
clock may result in violation of SCSI bus 
timing specifications. NOTE: A clock rate 
between 10 MHz and 12 MHz should not 


be used as the resulting SCSI bus clear | 


delay may violate SCSI specifications. 


Input Clk 
Frequency 
(MHz) 


Resulting 
Divisor 
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6.2.4 CDB Size Register 


Table 6-3. CDB Size Register 


[Bie7[Bic6 | Bes [ied [Bie [wie [wie [Bie 
Po fo fo | o [eles [csi | ca, 
Bits 0-3 CSx CDB SIZE bits 0-3 specify the SCSI CDB 
size for the Select-and-Transfer and Wait- 
for-Select-and-Receive commands when the 
command group is not 0, 1, or 5. This mode 


is enabled only when advanced features 
have been selected. 


6.2.5 Control Register 


The CONTROL register consists of option bits which affect 
the response to parity errors and to the SCSI attention 
condition, suppress certain interrupts, allow command 
chaining, and select the mode of DMA transfer. 


Table 6-4 


[Bi [Bie 6] BieS ie [BES | BH? [BHT BAO] 


Bit O 


Control Register 











HSP The HALT on SCSI PARITY ERROR bit 
enables the AIC-33C93C to terminate a 
command if a parity error occurs on an 
incoming SCSI data byte. Asynchronous 
transfers check parity on every byte; 
synchronous data transfers check parity on 
4096-byte boundaries in most cases. In the 
initiator role, the AIC-33C93C responds to 
a SCSI parity error by leaving the ACK pin 
asserted to inhibit any additional data 
transfers requests by the target and to 
facilitate error handling with the target. If 
Immediate Halts are enabled, a SCSI parity 
error during a synchronous Receive or 
Reselect-and-Receive command will abort 
the transfer before the 4096-byte boundary. 





The HALT on ATTENTION bit (target 
mode only) enables the AIC-33C93C to 
terminate a command if the initiator asserts 
AIN. The AIC-33C93C normally tests for 
the ATN condition before the start of a 
phase and on 4096-byte boundaries during 
data transfers. If the Immediate Halt feature 


Register Descriptions 


Bit2 IDI 
Bit3 EDI 
Bit4 HHP 
Bit 5-7 DMx 
10 


is enabled, an the AIC-33C93C will issue 
an abort command upon recognizing the 
attention condition. These rules apply to 
both synchronous and asynchronous 
transfers. 


The INTERMEDIATE DISCONNECT 
INTERRUPT bit, when set in the initiator 
role, causes the AIC-33C93C to terminate a 
Select-and-Transfer command and generate 
an 85 hex interrupt upon a proper target 
disconnect. When this bit is reset, the AIC- 
33C93C continues command execution and 
does not generate an interrupt. This feature 
combined with the Resume SAT command 
provides support for overlapped SCSI 
operations. In the target role, the 
INTERMEDIATE DISCONNECT 
INTERRUPT bit selects combination 
command execution options. 


The ENDING DISCONNECT 
INTERRUPT bit, when set, delays the 16 
hex interrupt which normally follows 
receipt of the Command-Complete message 
during a Select-and-Transfer command until 
after the target disconnects and eliminates 
the 85 hex interrupt. This bit also enables 
chaining between certain  target-role 
combination commands to reduce host 
system overhead. 


The HALT on HOST PARITY ERROR bit 
allows the AIC-33C93C to terminate a Send 
or Transfer Info command if a parity error 
occurs on an incoming host data byte. The 
AIC-33C93C checks for host parity errors 
according to the same rules it uses when 
checking for SCSI parity errors. However, a 
host parity error will not leave the ACK 
signal asserted. 


The DMA MODE SELECT bits 2-0 select 
the host bus transfer mode to be used during 


__a Data phase. The following table describes | | 


the different DMA modes and specifies the 
bit settings used to choose each mode: 
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Table 6-5 DMA Modes 


POLLED I/O MODE or no DMA 
enabled. The host must poll for DATA 
BUFFER READY in the AUXILIARY 
STATUS register and then, depending 
on the direction of the transfer, read or 
write the DATA register. 
BURST MODE or demand-mode 
DMA. In this mode, the DRQ signal 
will remain active so long as data or 
space exists in the internal FIFO to 
allow the transfer to continue. The 
DMA controller responds by asserting 
DACK and pulsing RE or WE to 
transfer the data. 

0 1 0 


WD-BUS MODE or Direct Buffer 
Access (DBA) mode. In this mode, the 
AIC-33C93C acts as a bus master, and 
all data access signals reverse their 
directions. The DRQ pin becomes the 
DRQ input, which when high, enables 
the AIC-33C93C to drive the buffer 
control signals. The DACK pin 
becomes the RCS output and serves as 
a chip select for the buffer. The RE 
and WE pins become outputs which 
drive the read and write functions of 
the RAM buffer. Transfers will 
continue in a burst manner until the 
transfer is complete or until the 
external buffer logic pauses the 
transfer by negating the DRQ signal. 
One transfer may occur after DRQ 
drops and then the DACK, RE, and 
WE signals will tristate. 





















DMA MODE or Single-byte DMA. 
In this mode, a DRQ/DACK 
handshake occurs for each byte. The 
DMA controller transfers the byte by 
asserting WE or RE while asserting _ 
DACK. 
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6.2.6 Time-out Period Register 


The value in the TIME-OUT PERIOD register specifies the 
time-out period for selection and reselection attempts and sets 
the minimum length of a AJC-33C93C-initiated SCAM 
selection phase. 


The time-out period specifies how long the AIC-33C93C will 
wait for a response, i.e. assertion of the BSY signal, after it has 
begun a reselection or selection phase, i.e. SEL asserted and 
BSY negated, before terminating the command. Loading this 
register with zero disables the time-out feature. 


During normal operation, the AIC-33C93C interprets the 
contents of the Time-out Period register according to the 
following equation: 


T per a Pioix 


register value = 30 


where Tyrer is the time-out period specified in milliseconds 
and Fj,j, is the input clock frequency in megahertz. 


When SCAM-tolerant timings are in effect, the relation 
becomes: 


125T 2. X Bucy 


per 


register value = 3q 


The SCAM Select command also uses the contents of this 
register to determine how long the selection phase should last 
according to the following equation: 


a ee x Fink 


register value = 0 


The constants scale the units of the equations, as it 1s based on 
an internal microcontroller cycle time. The user should round 
the resulting ‘register value’ up to the next integral value to 
ensure that the minimum time requirement is met. 


6.2.7 Command Descriptor Block Registers 


The COMMAND DESCRIPTOR BLOCK registers store the 
SCSI command bytes to be sent during Command phase of a 
Select-and-Transfer command and hold the command bytes 
received during the Command phase of a Wait-for-Select-and- 
Receive command. 


The Reset command places the microcode revision number in 
the CDB1 register when really advanced features are enabled. 


Register Descriptions 


The Send-Status-and-Command-Complete command uses the 
contents of the CDB11 register as the returned status and 
determines the type of the Command-Complete message to 
send from the contents of the CDB12 register. 


6.2.8 SCSI Control Bus Register 


Table 6-6 SCSI Control Bus Register 


[Bey [BiG [BES [BRA [BAS [BA HHT | BO 


The SCSI Control Bus register will reflect the state of the 
SCSI bus lines BSY, SEL, MSG, C/D, I/O, and ATN upon 
completion of a low-level SCSI YO command. The bits RAI 
and RAO indicate the state of REQ in and ACK out if the 
AIC-33C93C is in the Connected-as-a-Target state or in the 
Connected-as-a-SCAM-device state; otherwise, they indicate 
the state of ACK in and REQ out. If a bit is set, the 
corresponding SCSI control line is asserted. If a bit is not set, 
the internal microcontroller detected that the corresponding 
SCSI control line was negated, perhaps due to a wired-or 
glitch. It is the responsibility of the host processor to 
debounce the signals. 






This register is also used to specify the phase to be set by the 
Set Phase command. 


6.2.9 SCSI Data Bus Register 


The SCSI Data Bus register, in most cases, will reflect the 
state of the SCSI data bus upon completion of a low-level 
SCSI I/O Command. If a bit is set, the corresponding SCSI 
data bus line is asserted. If a bit is not set, the internal 
microcontroller detected that the corresponding SCSI data 
line was negated, perhaps due to a wired-OR glitch. It is the 
responsibility of the host processor to debounce the signals. 


If the Read SCSI Bus command is executed while in the 
Connected-as-an-Initiator state, this register will contain the 
value of the data latched on the last REQ pulse if the phase 
was an in phase. If the previous REQ pulse occurred during 
an out phase, the value returned in this register is 
unpredictable. 





The SCAM Transfer and Set Data Bus commands place the 


contents of this register onto the SCSI data bus. The SCAM 
Transfer command also uses this register to return the data it 
latches during the transfer cycle. 
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6.2.10 Target LUN Register 


The TARGET LUN register holds the Logical Unit Number 
(LUN) and other target status information during various AIC- 
33C93C commands and sequences. 


The Select-and-Transfer commands use the contents of this 
register and the SOURCE ID register to generate and check 
Identify messages. In addition, these commands also store the 
returned status byte from the target in this register. For proper 
operation of the Select-and-Transfer commands, the host 
should not set the TARGET LUN VALID bit in this register. 


In advanced mode, the Select-and-Transfer commands, in the 
event of an unexpected reselection, place the logical unit 
number or the target routine number of a reselecting target in 
this register The TARGET LUN VALID and 
DISCONNECTS OK bits will be zero. 


The Wait-for-Select-and-Receive command places a copy of a 
received Identify message in this register. If the TARGET 
LUN VALID bit is zero, the initiator did not send a valid 
Identify message. If the TARGET LUN VALID bit is one, the 
initiator sent a valid Identify message, and _ the 
DISCONNECTS OK bit will then indicate whether or not the 
initiator has enabled disconnects. The Wait-for-Select-and- 
Receive command will accept an Identify message with the 
TARGET ROUTINE bit set only if the host issues the 
command with the SINGLE BYTE TRANSFER bit in the 
COMMAND register set. 


The Reselect-and-Transfer commands use only the LUN 
portion and the TARGET ROUTINE bit of this register to 
generate the Identify message. The TARGET LUN VALID 
and DISCONNECTS OK bits are not used. 


Table 6-7 Target LUN Register 


[Bi [Bic [Bes [wes [BS [DBRT [BO 
pry [pox [re | -o[ 0 [rca [wu | Teo 


Bit 0-2 TLx 











Target LUN bit x 
BitS TRN _ Target Routine 

“ Bit6 DOK Disconnects OK 
Bit 7 


TLV ‘Target LUN valid 
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6.2.11 Command Phase Register 


The COMMAND PHASE register indicates which phases of a 
combination command have completed. Thus, if the 
command has terminated abnormally, the processor can read 
this register to determine the cause of the termination and 
decide how to respond to it. 


When resuming a combination command, the contents of this 
register specify from which point to restart the command. 
Refer to the description of the specific commands for details 
regarding the various command phases and resume values. 


Table 6-8 


Bey [BR [ies [we [BS [2 [BHT [BHO 
[0 [ers [ces [ cre | crs | Cra | crt | Cro 


Bit 0-6 CPx 


Command Phase Register 











Command Phase bit x 


6.2.12 Synchronous Transfer Register 


The contents of the SYNCHRONOUS TRANSFER register 
specify the maximum transfer rate and the transfer mode for a 
SCSI data phase. 


For information phases other than a Data phase or when the 
selected offset is zero (OF3=OF2=OF1=OFO0=0), the AIC- 
33C93C performs asynchronous transfers. A non-zero offset 
value, which should be twelve or less, selects synchronous 
data transfers and determines the effective FIFO depth. This 
value is typically determined through negotiation (as defined 
in the SCSI standard) with the other SCSI device. 


The Transfer Period control bits select the minimum transfer 
period for both synchronous and asynchronous SCSI data 
transfers and, in WD-Bus mode, the transfer period and the 
width of the RE/WE strobes for host transfers; for non-data 
transfers, the transfer period defaults to six periods. The 
period is defined in terms of the internal clock cycle time, 
which depends upon the input clock, the divisor selected in 
the OWN ID register, and the setting of the FAST SCSI 
SELECT bit. 


"The FAST SCSI SELECT bit has effect only when operating 


with an input clock frequency of 16-20 MHz, i.e. the divisor 
set to 4. Setting this bit enables Fast SCSI transfers, doubling 
the maximum transfer rate for synchronous transfers. For 
example, with a 20 MHz input clock and a transfer period of 2, 
the normal maximum transfer rate would be 5 MB/s; the Fast 
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SCSI transfer rate would be twice this value or 10 MB/s. The 
FAST SCSI SELECT bit does not affect the rate of 
asynchronous transfers. 


Table 6-9 | Synchronous Transfer Register 


Bit 0-3 OFx 











The OFFSET bits specifies the desired 
offset according to the following table: 





Bit 4-6 TPx The TRANSFER PERIOD bits select the 
desired transfer period according to the 
following table: 
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oa es o. REQ/ACK 
ieee eee width 





a. Tp is the SCSI/WD Bus Transfer cycle time 


Tcyc is the period of the internal data transfer clock. For 
asynchronous transfers or for synchronous transfers when the 
input clock frequency is less than 16 MHz, it is calculated as 
follows: 


7 DIVISOR(fromOWNID) 
cye ~ 2X Input Clock Frequency (MHz) (is) 


When the input clock frequency is 16 MHz or greater, the. 
cycle time for synchronous transfers is calculated as follows: 


2 
Teye = TESS41) xInp InputClockFrequency(MHz) (HS) 


Bit7 FSS The FAST SCSI SELECT bit under the 
conditions mentioned above enables the 
doubling of the internal clock frequency 
resulting in a synchronous transfer rate up 
to 10 MB/s. It applies only to the 


synchronous transfer phase. 


Note: The Fast SCSI mode cycle time applies to synchronous 
data transfer phase only. For all asynchronous transfer phases 
including command, message and data, the first equation 
applies. Also note that if FAST SCSI SELECT mode bit is 
set, it affects the host side DMA timing as well. See section 
9.2 for detailed timings. 


6.2.13 Transfer Count Register 


The TRANSFER COUNT register, a 24-bit register, stores a 
preset value for the internal transfer counter. A Send, Receive, 


| or Transfer Info command causes the AIC-33C93C to load this 
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preset value into the internal transfer counter, which then 
decrements as each data byte is transferred over the SCSI bus 
and causes a “successful completion” interrupt when it 
reaches zero. 


Loading the TRANSFER COUNT register with zeros prior to 
issuing these command or issuing the command with the 
SINGLE BYTE TRANSFER bit set in the COMMAND 
register disables the counter function. If the counter is 
disabled, the Send, Receive, or Transfer Info command will 
complete when a single byte has been transferred. 


In combination commands, this register specifies the number 
of bytes to be transferred during a Data phase. A zero value 
indicates the lack of a Data phase. 


After the completion of any successful transfer, unless the 
command was issued in Single Byte Transfer mode (see 
6.2.17), the TRANSFER COUNT register will be zero. 


When a transfer halts because of an error condition, a SCSI 
bus phase change, or an abort, the TRANSFER COUNT 
register will contain the number of bytes NOT successfully 
transferred over the SCSI bus, including any bytes present in 
the FIFO at the time of the interruption. The FIFO clearing 
process may cause the TRANSFER COUNT register to differ 
with the host DMA controller count because some bytes may 
have been transferred into the FIFO but not to the SCSI bus. 


6.2.14 Destination ID Register 


The DESTINATION ID register stores the encoded SCSI bus 
ID of the device to be selected or reselected. This register also 
contains control bits that affect the operation of certain 
combination commands. 


Table 6-10 Destination ID Register 


a7 [wie [Bis [Bie [i> [Bie [BA [BH 


[sec bro] pF [Tor [T60 [De [DI | BIO 


Bit 0-2 DIx 





Destination ID bit x 


Bit3-4 TGx |The TAG MESSAGE bits select which tag 
Transfer and identify which tag message 
code was received by the Wait-for-Select- 
and-Receive command. In addition, the 
Reselect-and-Transfer commands send a 
Simple-Queue Tag message following the 
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Identify message if either of these bits are 
set. 


Po Po [eM 
To [Si og) 
Toes a re) 
[7 [od Oa 2) 


BitS DF 













DISABLE FEATURE, when set, disables 
Data phase direction checking in advanced 
mode and inhibits the normally automatic 
link from Send-Status-and-Command- 
Complete to the command fetch portion of 
Wait-for-Select-and-Receive when a Linked- 
Command-Complete message is sent. 

Bit6 DPD DATA PHASE _ DIRECTION, when 
advanced features are enabled (see 7.5), 
specifies the expected direction of the SCSI 
Data phase of a _ Select-and-Transfer 
command. When this bit is zero, the 
expected direction is out (to the target), and 
when this bit is one, the expected direction 
is in (from the target). An unexpected data 
phase error will] occur if the actual direction 
does not match the setting of this bit. 

Bit7 SCC SELECT COMMAND CHAIN sselects 
which command will follow a Reselect-and- 
Transfer command when chaining is 
enabled. When this bit is zero, a Send- 
Status-and-Command-Complete command 
will follow; when this bit is one, a Send- 
Disconnect-Message command follows. 


6.2.15 Source ID Register 


The SOURCE ID register is used to report the SCSI bus ID of 
the device that has selected or reselected the AIC-33C93C. It 


_ also contains bits that enable and control response to selection 


and reselection. 
Table 6-11 Source ID Register 


[BRT [BRS BRS [Bia [eS [Bw [Bi [BHO 
par [es [os] 0 [sv [se [su [s0_ 
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Bits 2-0 SIx SOURCE ID Bits 2-0, valid only if the 
SOURCE ID VALID bit is set, indicate the 
SCSI bus ID of the device that selected or 
reselected the AIC-33C93C. 

Bit3 SIV SOURCE ID VALID is set to one when the 
AIC-33C93C is selected or reselected and 
the other SCSI bus device asserted its own 
bus ID bit during the Selection/Reselection 
phase. This bit is zero if only the bus ID bit 
of the AIC-33C93C was asserted. 

BitS DSP DISABLE SELECT PARITY, when set, 
causes the AIC-33C93C to ignore the bus 
parity when responding to selection or 
reselection. 

Bit6 ES ENABLE SELECTION, when set, allows 
the AIC-33C93C to respond to selection by 
another device on the SCSI bus. 

Bit7 ER ENABLE RESELECTION, when set, 
allows the AIC-33C93C to respond to 
reselection by another device on the SCSI 


bus. 


6.2.16 SCSI Status Register 


The SCSI STATUS register, a read-only register, holds a value 
which indicates the cause of the most recent INTRQ 
assertion. The AIC-33C93C asserts INTRQ whenever a 
condition occurs that requires intervention by the host. For 
example, 

« the AIC-33C93C has been reset; 

¢ the command completed successfully; 


¢ the bus phase changed; 


° an error occurred. 


After assertion of INTRQ, the contents of this register will not 
change until the host reads the register or until the AIC- 
33C93C has been reset. 


Table 6-12 SCSI Status Register 


7 [BiG [Bes [ied [BS [BD [BH [BIC 
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Bit 0-3 SSx SCSI STATUS bits 0-3 are status qualifiers 
with meanings that depend upon the upper 
(4-7) status bits. 

Bit4-7 SSx SCSI STATUS bits 4-7 define the type of 


interrupt that occurred. The following table 
describes the various types: 


The AIC-33C93C is in a reset state. 


0001 xxxx A AIC-33C93C command has 
completed successfully. 

0010 xxxx A AIC-33C93C command has 
paused or was aborted. 


0100 xxxx A AIC-33C93C command has been 
terminated prematurely due to an 


error or other unexpected condition. 


1000 xxxx An event on the SCSI bus requires 
service. 


All other Status Code groups are currently not used and are re- 
served for future use. 





In the following tables, the ‘STATE’ column indicates the 
state---Disconnected, Target, Initiator, or SCAM---from 
which the Status Code can occur. The MCI field refers to the 
signals that define a SCSI bus information transfer phase: 
MSG, C/D, and I/O. A bit set to one indicates that the signal 
is asserted on the SCSI bus; a zero indicates negation. The 
table below summarizes the meaning of the MCI field: 
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| Table6-13 | MCI Field Meaning 


[Mcrae 


Data Out Phase 


Data In Phase 


[or ears 














Table 6-14 Reset State Interrupts 








Specific Meaning 


DTIS | 33C93 Reset. The device has been hard 
reset, or a Reset command has 
executed successfully with no 
advanced features enabled. The new 
state of the AIC-33C93C is 
disconnected. 


DTIS | AIC-33C93C Reset. The device has 
successfully completed a Reset 
command with advanced features 
enabled. The new state of the AIC- 
33C93C is disconnected. 


| Table 6-15 Successful Completion Interrupts 


Specific Meaning 


“A Reselect command completed 
successfully. The new state of the AIC- 
33C93C is connected as a target. 
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Table 6-15 Successful Completion Interrupts 


Specific Meaning 


A Select command completed 
successfully. The new state of the AIC- 
33C93C is connected as an initiator. 


A SCAM Select command completed, 
and a SCAM master is present on the 
bus. The new state of the AIC-33C93C 
is connected as a SCAM device. 


A Receive, Send, Reselect-and- 
Transfer, Wait-for-Select-and-Receive, 
Send-Status-and-Command-Complete, 
or Send-Disconnect-Message 
command completed successfully 
(ATN is not asserted) 


A Receive, Send, Reselect-and- 
Transfer, Wait-for-Select-and-Receive, 
or Send-Status-and-Command- 
Complete command completed 
successfully (ATN is asserted). 


A SCAM Transfer command 
completed successfully. 


A Select-and-Transfer command 
completed successfully. 


A SCAM Select command completed, 
and a SCAM master did not respond. 
The state of the AIC-33C93C is 
Disconnected. 


A Transfer Info (non-Message-In 
phase) command completed 
successfully. MCI defines the new 
information type (SCSI bus phase) 
requested. 
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| Table 6-16 Paused or Aborted Interrupts 


| Table 6-16 Paused or Aborted Interrupts 


Specific Meaning 


A Transfer Info (Message In phase) 
command has paused with ACK 
asserted, giving the host the 
opportunity to reject the message. 


A Save-Data-Pointer message was 
received during a Select-and-Transfer 
command. The host should save its 
current data buffer pointer 


A Select, Reselect, or Wait-for-Select- 
and-Receive command aborted. 


A Receive or Send command aborted, 
or a Wait-for-Select-and-Receive 

| aborted because of an error in the 
Identify message. (ATN is not asserted). 


A command aborted or halted due to 
assertion of ATN, or a Wait-for-Select- 
and-Receive aborted because of an error 
in the Identify message. (ATN is 
asserted). 


A transfer has aborted because of a 
violation of the data transfer protocol, 
possibly corrupting the data. 


An I/O process with a queue tag which 
did not match the value in the QUEUE 
TAG register reselected the AIC- 
33C93C. ACK has been left asserted, 
and the received tag is in the 

QUEUE TAG register. 
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A target whose SCSI bus ID does not 
match the ID in the DESTINATION ID 
register reselected the AIC-33C93C or 
the following Identify message did not 
match the LUN in the TARGET LUN 
register. ACK has been left asserted 
following the Identify message, and the 
bus ID and LUN of the reselecting 
target are available in the SOURCE ID 
and TARGET LUN registers. This 
status only occurs when executing a 
Select-and-Transfer in advanced mode. 





An unexpected disconnect occurred. 
The new state of the AIC-33C93C is 
disconnected. 


A time-out occurred during a Select or 
Reselect command. The state of the 
AIC-33C93C is disconnected. 


A parity error caused a command to 
terminate (ATN is not asserted). The 
transfer direction determines whether it 
was a SCSI or host parity error. 


A parity error caused a command to 
terminate (ATN is asserted). The 
transfer direction determines whether it 
was a SCSI or host parity error. 
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Table 6-17 Terminated Interrupts (Continued) Table 6-18 Service Required Interrupts 


Specific Meaning 


] The AIC-33C93C detected the 
negation of C/D at the beginning of a 
SCAM Transfer command. The new 

] state of the AIC-33C93C is 
disconnected. 


A target whose SCSI bus device ID 
does not match the bus ID set in the 


DESTINATION ID register has 

[ reselected the AIC-33C93C during a 
Select-and-Transfer command. This 

] interrupt occurs when the AIC-33C93C 


is not in advanced mode. The state of 
| the AIC-33C93C is connected as an 
initiator. 


A status byte with a parity error was 
received during a Select-and-Transfer 
command. 


An unexpected information phase was 
requested. MCI defines the SCSI bus 
phase requested. This interrupt typically 
occurs when the phase changes before 
the Transfer Count reaches zero during 
a Transfer Info command or when an 
unexpected phase sequence occurs 
during a Select-and-Transfer command. 










The AIC-33C93C has been reselected. 
The new state of the AIC-33C93C is 
connected as an initiator. 
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The AIC-33C93C has been reselected 
in advanced mode. The Identify 
message from the target must be read 
from the DATA register. The ACK 
signal is asserted. The new state of the 
AIC-33C93C is connected as an 
initiator. 


The AIC-33C93C has been selected 
(AIN was not asserted). The new state 
of the AIC-33C93C is connected as a 


The AIC-33C93C has been selected 
(ATN was asserted). The new state of 
the AIC-33C93C is connected as a 


The target has disconnected. The new 
state of the AIC-33C93C is 
disconnected. 


The AIC-33C93C has been SCAM 
selected. The new state of the AIC- 
33C93C is connected as a SCAM 


The Wait-for-Select-and-Receive 
command has paused because the 
incoming CDB is not of a known 
command group. The host can examine 
the opcode stored in the CDB1 register 
to determine the number of command 
bytes expected. The new state of the 
AIC-33C93C is connected as a target. 
(Advanced mode only) 


The REQ signal has been asserted 
while the AIC-33C93C was in an idle 


| initiator state. The information-phase 


type should be examined. MCI defines 
the information phase (SCSI bus 
phase) requested. 
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6.2.17 Command Register 


The COMMAND register is used to issue the AIC-33C93C 
commands. The host should never write to this register when 
the COMMAND IN PROGRESS or INTERRUPT PENDING 
bits in AUXILIARY STATUS register are set and should 
never issue a Level IJ command when the BSY bit is set. 


The SINGLE BYTE TRANSFER bit in the COMMAND 
register affects the Send, Receive, and Transfer Info 
commands by disabling the TRANSFER COUNT register and 
specifying that only one byte is to be transferred. The original 


€ 1 Vv 


The SINGLE BYTE TRANSFER bit also affects the Wait-for- 
Select-and-Receive command. Normally, this command does 
not accept as valid an Identify message with the LUNTAR bit 
set, which occurs when the initiator wishes to communicate 
with a target routine. Issuing the command with the SINGLE 
BYTE TRANSFER bit set allows it to accept an Identify 
message for a target routine. 


The SINGLE BYTE TRANSFER bit also selects whether the 
AIC-33C93C behaves as a level 1 SCAM master (SBT=0) or 
as a level 2 SCAM slave (SBT=1) when executing a SCAM 
Select command. 


All other commands ignore the setting of this bit. 


Refer to the COMMANDS section for a description of the 
commands and their corresponding command codes. 


Table 6-19 Command Register 


Bi7 [BiG [BRS [Rica | BRS [RDB [BHO 


6.2.18 Data Register 











The DATA register provides an interface between the internal 
twelve byte FIFO and the host. During any type of information 
phase, the host may access this register with the processor, 
and during a SCSI Data phase, the host may also access this 
register through the DMA interface. 


The processor, except in one case, should only access the 
DATA register when the DATA BUFFER READY bit in the 
AUXILIARY STATUS register is true. The exception occurs 
when the AIC-33C93C is reselected while operating in 
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advanced mode: the processor must retrieve the Identify 
message from the target by reading the DATA register. 


The FIFO FULL/EMPTY bit in the AUXILIARY STATUS 
register enables the host to avoid polling DATA BUFFER 
READY in some cases. This bit, when the host writes to the 
FIFO, acts as a FIFO empty indicator; thus, when set, the host 
can safely write up to eleven bytes to the FIFO without 
polling for DATA BUFFER READY between each write. 
Similarly, when the transfer direction is to the host, the FIFO 
FULL/EMPTY bit indicates the FIFO full condition, and the 
processor can safely read twelve bytes from the FIFO without 
checking for DATA BUFFER READY before each read. In 
both cases, the host should consider the FIFO FULL/EMPTY 
bit valid only when DATA BUFFER READY is set. 


Two exceptions do exist, however, when writing to the DATA 
register. First, after the initial setting of the FIFO 
FULL/EMPTY and DATA BUFFER READY bits in response 
to a Transfer Info or Send command, the host-may write 
twelve bytes to the FIFO without causing a FIFO overrun. 


Second, because the AIC-33C93C splits a Transfer Info 
command into two separate transfers when responding to a 
message out phase, the host must not write the last message 
byte to the DATA register until the AIC-33C93C specifically 
requests that byte. For instance, if the host wishes to send a 
(five-byte) Synchronous Data Transfer Request message, the. 
first set of writes should contain only the first four bytes of the 
message. The host must then poll for DATA BUFFER 

READY before writing the final byte. 


Care should be taken when transferring a large block of data 
(more than 4 KByte) using FIFO FULL/EMPTY bit to 
guarantee the maximum burst length. The AIC-33C93C 
empties FIFO at every 4,096 byte boundary in order to 
match the number of bytes transferred on the SCSI bus 
and the host bus. If, for example, during the data read (from 
the SCSI bus) operation, data bytes are in the FIFO but not 
full at the 4,096 byte boundary, FIFO FULL/EMPTY bit will 
not be set, and the SCSI transfer halts until these bytes are read 
out. 


The processor normally should not access the DATA register 
during a Data phase unless the host has selected polled I/O 
mode by setting all of the DMA MODE SELECT bits in the 
CONTROL register to zero. In exceptional cases, such as 
aborting a transfer, the host may wish to switch to polled /O 
accesses. In this case, the processor may access the DATA 
register but must guarantee that the DMA interface is 
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inactive, i.e. DACK inactive in the DMA and Burst DMA 
modes and RCS negated in AIC- Bus mode. 


6.2.19 Queue Tag Register 


The QUEUE TAG register holds the second byte of the Tag 
messages associated with the Select-and-Transfer, Reselect- 
and-Transfer, and Wait-for-Select-and-Receive commands. 


The Select-and-Transfer and  Reselect-and-Transfer 
commands send the contents of this register as the second 
byte of the Tag message during the Tag message out phase. 


The Select-and-Transfer and Wait-for-Select-and-Receive 
commands place the received queue tag byte into this register 
during the Tag message in phase. The Select-and-Transfer 
commands, furthermore, compare the received byte with the 
contents of the register and generate an interrupt in the case of 
a mismatch. 


6.3 Reset Conditions 


6.3.1 Hardware Reset 


A hard reset, caused by assertion of the MR signal, will result 
in the following conditions: 


e The AUXILIARY STATUS register is reset to zero. The 
INTERRUPT PENDING bit and the INTRQ pin are set 
when the hardware reset completes. 


¢ The OWN ID register is reset to zero. 
¢ The advanced and really advanced modes are disabled. 


¢ The ES, ER, and DSP bits in the SOURCE ID register are 
reset to zero. 


¢ The SCSI STATUS register is reset to zero. 
¢ The SCSI bus signals are released. 


¢ The internal FIFO, internal transfer counter (not the host 
accessible register), offsets, and-state machines are cleared. 


¢ The internal clock divider circuit is set to divide by two. 


The hard reset does NOT affect the following host-accessible 
registers: 
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* Registers 01 hex through 15 hex; 
e SOURCE ID (16 hex) register bits 0-3; 


° COMMAND register (18 hex); 


NOTE: The SCSI Soft Reset may be implemented by using the 
SCSI bus reset signal to reset the AIC-33C93C (for example, 
logically or the host power-on reset signal with the received 
SCSI bus reset (RST) signal). The host may examine the 
registers that are not affected by the MR signal to recover 
from the SCSI reset condition. 


6.3.2 Software Reset 


A soft reset, caused by executing the Reset command, will 
result in the following conditions: 


¢ The DATA BUFFER READY bit in the AUXILIARY 
STATUS register is reset to zero. The INTERRUPT 
PENDING bit and INTRQ pin are set when the Reset 
command is complete. 


¢ The SCSI bus signals are released. 


¢ The internal FIFO, internal transfer counter (not the host 
accessible register), offsets, and state machines are cleared. 


e The clock divisor, host parity, and operating mode are 
configured according to the contents of the OWN ID 
_ Tegister. 


¢ The registers 01 hex through 16 hex are reset to zero. The 
COMMAND register (18 hex) is also reset to zero. 


¢ The SCSI STATUS register is set consistent with the 
setting of the ENABLE ADVANCED FEATURES bit in 
the OWN ID register. 
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7.0 Commands 


7.1 Command List 


Cmd Valid 
Code Command State Level 
(hex) é 


ee 
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Select-without-ATN-and- 
Transfer 


0 Reselect-and-Receive-Data 
Reselect-and-Send-Data 
0 Wait-for-Select-and-Receive 


Send-Status-and-Command- 
Complete 


05 
07 
A 
Cc 
OE | Send-Disconnect-Message 
Set IDI TI 


ses 
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1 
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ped 


ie [save 
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Cmd Valid 
Code Command State Level 
(hex) : 
















[2c [ae Sca TTn |D | 
[ab [Rniescansenion [> [1 
[ae [scamseen 


AIC-33C93C states: 








Command Levels: 


I= Level I command 
II = Level IJ command 


D = Disconnected 

T = Connected as a target 

I = Connected as an initiator 

S = Connected as a SCAM device 


7.2 AIC-33C93C Command Types 


The AIC-33C93C command set consists of two types of 
commands: Level I and Level II commands. Level I 
commands, except for the Reset and Abort commands, do not 
generate interrupts upon their completion; Level II commands 
always terminate with an interrupt. The host may issue some 
Level I commands while a Level II command is executing. The 
AIC-33C93C will ignore a Level II command issued while 
another Level II command is already executing. 


The AIC-33C93C operates in one of four states at any one 
time: disconnected, connected-as-a-target, connected-as-an- 
initiator, or connected-as-a-SCAM-device. In each state, the 
AIC-33C93C recognizes only certain commands as valid, as 
indicated in the command list above. An attempt to issue a 
Level II command invalid for the present AIC-33C93C state 
will cause an “invalid command” interrupt. Level I commands 
issued in invalid states will be ignored. 


There are two types of Level IT commands. ‘Simple’ Level II 
commands perform a single operation (e.g. selection) or 
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single phase (e.g., Command phase). ‘Combination’ Level II 
commands combine multiple phases into a single AIC- 
33C93C command to minimize interrupt overhead. 


The initiator combination commands expect the target to 
follow common SCSI bus phase sequences. Any deviation 
causes an interrupt. 


The ENDING DISCONNECT INTERRUPT and 
INTERMEDIATE DISCONNECT INTERRUPT bits in the 
CONTROL register and the SELECT COMMAND CHAIN 
bit in the DESTINATION ID register enable and control 
chaining of target combinations command. Linking 
commands further decreases interrupt overhead by creating 
longer phase sequences. When using command chaining, the 
host must initialize all commands in the chain prior to starting 
the sequence. 


7.3 Differentiating between the AIC-33C93 and 
the AIC-33C93C 


The AIC-33C93C incorporates two sets of features, both of 
which cause it to be incompatible with the original 33C93 
design. Upon completion of a hardware reset, both sets of 
features are disabled. The host enables them by soft resetting 
the AIC-33C93C with the ENABLE ADVANCED 
FEATURES and REALLY ADVANCED FEATURES bits in 
the OWN ID register set appropriately. An advanced mode 
reset results in a 01 hex being loaded into the SCSI STATUS 
register instead of the 00 hex which normally results from a 
reset. This difference gives the host a method to deduce that a 
AIC-33C93C is installed as opposed to a AIC-33C93. 


7.4 Differentiating between the AIC-33C93A , 
the AIC-33C93B, and the AIC-33C93C 


All three devices implement two of the features included in 
the set of really advanced features. However, the AIC- 
33C93B and AIC-33C93C implement additional features 
which result in interrupts which would not occur when using 


the AIC-33C93A, hence making the two devices incompatible | 


with the AIC-33C93A. 


Commands 


7.5 Advanced Mode Features 


7.5.1 Unexpected Reselection 


When in normal (33C93) mode, a reselection when idle or a 
reselection during a Select-and-Transfer command by an 
target whose ID does not match the one in _ the 
DESTINATION ID register causes an interrupt immediately 
after the reselection handshake finishes. In advanced mode, the 
AIC-33C93C will continue to the Message In phase to fetch 
the Identify message. If the AIC-33C93C was idle, the SCSI 
STATUS register will be set to 81 hex, and the Identify 
message will be in the DATA register. This byte must be 
read out. If the AIC-33C93C was executing a Select-and- 
Transfer command, the SCSI STATUS register will be set to 
27 hex, and the logical unit number will be in the TARGET 
LUN register. In both cases, the SOURCE ID register will 
contain the SCSI bus ID of the reselecting target, and the 
ACK signal remains asserted so that the Identify message may 
be rejected if desired. 


Any message other than a valid Identify message will result in 
an unexpected message in phase interrupt. If the unexpected 
reselection occurs during a Select-and-Transfer command, a 
parity error will cause an unexpected message in phase 
interrupt only if the halt-on-SCSI-parity-error feature is 
enabled. If reselected from an idle state, the AIC-33C93C will 
halt on a parity error regardless of the setting of the HALT on 
SCSI PARITY ERROR bit. The host can retrieve the byte 
with the Transfer Info command. 


7.5.2 Unknown SCSI Command Groups 


The length of a SCSI Command Descriptor Block is 
determined by the group code, found in bits 7-5 of the first 
command byte. The SCSI standard (X3.131-1986) defines 
Group 0 (opcodes 00 to IF hex), group 1 (opcodes 20 to 3F 
hex), and group 5 (opcodes AO to BF hex) commands 
respectively as six, ten, and twelve byte commands. All other 
command groups are undefined by that standard. In normal 
mode, the AIC-33C93C assumes a length of six bytes for 
these undefined groups when executing a Select-and-Transfer 
or Wait-for-Select-and-Receive command. In advanced mode, 


By inspecting the microcode revision, the host can deduce | the AIC-33C93C behaves as follows: 


which type of device is installed. 
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¢  Select-and-Transfer: When sending a command from an 
unknown group, the host must load the expected command 
length into the CDB SIZE register before issuing the 
Select-and-Transfer command. The AIC-33C93C uses this 
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value to make sure the correct number of bytes are | 


transferred in the Command phase. 


¢ Wait-for-Select-and-Receive: When receiving the CDB 
from the initiator, the AIC-33C93C examines the first CDB 
byte to determine the command group. An undefined group 
results in an interrupt with the SCSI STATUS register set to 
87 hex and the COMMAND PHASE register set to 31 hex. 
The host may examine the byte, available in the CDB1 
register, to determine the TOTAL command length, which 
it then places into the CDB SIZE register, before resuming 
the Wait-for-Select-and-Receive command. 


After this interrupt, the AIC-33C93C will only accept a 
Resume Wait-for-Select-and-Receive, Abort, Disconnect, 
or Reset command. All other commands are invalid. While 
the host processes the interrupt, the AIC-33C93C 
continues to transfer the first six bytes of the SCSI 
command into its internal FIFO. 


7.5.3 Data Phase Direction 


Normally during a Select-and-Transfer command, the target 
solely determines the direction of the Data phase. The AIC- 
33C93C will not detect a mismatch between this direction and 
the one expected by the host and will proceed with the transfer. 


| In advanced mode, the AIC-33C93C compares the DATA 


PHASE DIRECTION bit in the DESTINATION ID register 
with the state of the I/O signal on the SCSI bus. If the expected 
and actual directions do not match, an interrupt will occur with 
an ‘unexpected phase’ status in the SCSI STATUS register. 
Setting the DISABLE FEATURE bit in the DESTINATION 
ID register disables this feature. 


7.6 Really Advanced Features 


7.6.1 Microcode Revision 


The AIC-33C93C will load the revision number of the 
microcode into the CDB1 register during the reset sequence 
when really advanced features are enabled. 


7.6.2 Immediate Halt 


The AIC-33C93C normally checks for parity errors during a 
synchronous transfer and for the attention condition during 
both asynchronous and synchronous transfer on 4096-byte 


boundaries. With really advanced features enabled, the AIC- I 
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33C93C during a Receive command continuously checks for 
these conditions and upon detecting one issues an Abort 
command. 


7.6.3 Data Transfer Protocol Error 


The AIC-33C93C, if it detects a possible transfer corruption 
caused by noise on the REQ and ACK signals, will abort a 
Send or Receive command and generate a 25 hex interrupt. 
The detection scheme can not catch all possible failures due 
to the nature of the SCSI transfer protocols; however, this 
feature does provide some protection against data integrity 
faults. 








7.6.4 Unexpected Bus Free Interrupts 


The AIC-33C93C will generate either an 85 hex interrupt or a 
41 hex interrupt in the event that a glitch on the SEL signal 
causes the device to disconnect from the SCSI bus. 


7.7 Level I Commands 


7.7.1 Reset (00 hex) 


The Reset command initializes the AIC-33C93C according to 
the contents of the OWN ID register and as described in the 
RESET CONDITIONS section. The host may issue the Reset 
command while in any state, forcing the AIC-33C93C into a 
disconnected state; any command executing at that time will 
terminate. Upon completion of the Reset command, the AIC- 
33C93C will generate an interrupt with the SCSI STATUS 
register containing a OO hex or a 01 hex depending upon the 
contents of the OWN ID register at the time of the reset. 


7.7.2 Abort (01 hex) 


The Abort command is valid in the disconnected and 
connected-as-a-target states. The effect of the command 
depends on the current state and the command that is 
currently executing, as described below: 


¢ Disconnected State: In this state, the Abort command will 
halt a selection or reselection attempt of a Select, Select- 
and-Transfer, Reselect, or Reselect-and-Transfer command 
or will halt the Wait-for-Select-and-Receive command 
before selection. Aborting a selection or reselection 
attempt before the AIC-33C93C has won arbitration 


23 


Level I Commands 


immediately returns the AIC-33C93C to an idle state and 
generates a “‘paused/aborted” interrupt. If the AIC-33C93C 
has already won arbitration, the Abort command causes the 
AIC-33C93C to remove the Bus ID bits from the SCSI bus 
while maintaining assertion of SEL. If the target does not 
respond within at least 200 us by asserting BSY, the AIC- 
33C93C will go to a Bus Free condition and generate a 
“paused/aborted” interrupt. If the target does respond 
within this time period, a “successful completion” interrupt 
will result instead. . 


The Abort command, in addition, will terminate a Select- 
and-Transfer command if the target has disconnected from 
the bus. The AIC-33C93C will generate an 85 hex interrupt 
and will be in the Disconnected state. If the target is still 
connected at the time the Abort command is recognized, 
the command will be ignored. 


¢ Target State: In this state, the Abort command will 
terminate a Receive or Send command or the Data phase 
portion of a Reselect-and-Transfer command. The 
following rules apply when aborting a transfer: 


e During a Send or Reselect-and-Send command, the 
AIC-33C93C removes the data request (DRQ or the 
DATA BUFFER READY bit) at an arbitrary time 
during the abort procedure. The host must NOT 
service any data request once it has written the Abort 
command to the COMMAND register until the AIC- 
33C93C generates an interrupt. Abort processing will 
not complete until the contents of the FIFO are flushed 
to the SCSI bus. 


¢ During a Receive or Reselect-and-Receive command, 
the host must CONTINUE to service any data request 
from the AIC-33C93C. Abort processing will not 
complete until the contents of the FIFO are flushed to 
the host. 





After completion of the Abort command, the TRANSFER 
COUNT register contains the number of bytes that were not 
transferred across the SCSI bus. The AIC-33C93C remains in 
the connected-as-a-target state and will accept any target 
mode command, including a resume of the aborted command. 


_ 7.7.3. Disconnect (04 hex) 


The Disconnect command, valid in the initiator, target, and 
SCAM states, causes the AIC-33C93C to release all SCSI 
signals and return to the disconnected state, and in the 
initiator and target states, it will immediately terminate an 
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active Level II command. In the target and SCAM roles, the 
Disconnect command is the normal procedure for 
disconnecting from the SCSI bus following the information 
transfer phase. In the initiator role, this command can be used 
to release the bus following a time-out condition. 


7.7.4 Assert ATN (02 hex) 


The Assert ATN command, valid only when connected as an 
initiator, allows the initiator to inform the target that it has a 
message pending. The target should respond with a Message 
Out Phase. ATN is automatically negated: 


¢ before the last byte of a Transfer Info command issued in 
response to the Message Out phase; 


¢« when the Identify message out is transferred to the target 
during a Select-and-Transfer command; 


* when a SCSI Bus Free phase occurs. 


The Select-with-ATN and  Select-with-ATN-and-Transfer 
commands will cause the AIC-33C93C to assert AIN 
automatically prior to the release of SEL. 


7.7.5 Negate ACK (03 hex) 


The Negate ACK command causes the AIC-33C93C to 
release ACK which for some reason it has held active. 
Holding ACK active allows the host to respond to information 
it has just received before the target continues the current 
phase or proceeds to the next one. The AIC-33C93C, 
therefore, does not negate ACK before generating an interrupt 
in the following cases: 





¢ after successful completion of a Message-In Transfer Info 
command; 


¢ after detection of a parity error on any received SCSI 
information when the HALT on SCSI PARITY ERROR bit 
is set; 


¢ after unexpected reselection in advanced mode; 


* after reception of a save-data-pointer message during a 
Select-and-Transfer command; 


* after reselection by a process with a queue tag which 
differs from the contents of the QUEUE TAG register; and 
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* after reception of a status byte with a parity error during a 
Select-and-Transfer command. 


ACK negates automatically for all initiator transfers other 
than Message In transfers. Host parity errors, moreover, do 
not affect the ACK signal. 





Before completing a Message In phase, the initiator, upon 
examining the message, may decide to reject it and send a 
“MESSAGE REJECT” message to the target or, upon 
detecting a parity error in the message, may decide to send a 
“MESSAGE PARITY ERROR” message to the target. 
Similarly, if a parity error causes a transfer command to 
terminate, the initiator may wish to send an “INITIATOR 
DETECTED ERROR” message to the target. In all cases, the 
initiator signals its intent to send a message by asserting ATN 
before issuing the Negate ACK command. 


7.7.6 Set IDI (OF hex) 


The Set IDI command provides support for overlapped SCSI 
operations in the initiator role. The host may start a SCSI 
operation with the INTERMEDIATE DISCONNECT 
INTERRUPT bit reset, allowing the AIC-33C93C to handle 
target disconnects and reconnects and thus minimizing the 
interrupt handling overhead. When it wishes to start a second 
operation, the host issues the Set IDI command so that if the 
current target disconnects and releases the SCSI bus, the AIC- 
33C93C will produce an interrupt. The host may now start the 
second operation without having had to wait for the first 
operation to complete. 


7.7.7 Set Phase (28 hex) 


The Set Phase command, valid in the SCAM state, sets the 
SCSI bus phase pins MSG, C/D, and I/O as specified by the 
value in the SCSI Control Bus register. It ignores bits 3 
through 7 of the register. 





7.7.8 Set Data (29 hex) 


The Set Data command, valid in the SCAM state, places the 
data specified in the SCSI Data Bus register onto the SCSI 
data bus, with the proper parity. 
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7.7.9 Read SCSI Bus (2A hex) 


The Read SCSI Bus command, valid in all states, returns the 
state of the SCSI bus control lines and in most cases the SCSI 
bus data lines in, respectively, the SCSI Control Bus register 
and the SCSI Data Bus register. 


If the Read SCSI Bus command is executed while in the 
Connected-as-an-Initiator state, the SCSI Data Bus register 
will contain the value of the data latched on the most recent 
REQ pulse if the phase was an in phase. If the pulse occurred 
during an out phase, the value returned in the register is 
unpredictable. 


7.7.10 Enable SCAM Tolerant Timings (2C hex) 


The Enable SCAM Tolerant Timings command alters two 
timings involved during the reselection and selection phases. 
First, the AIC-33C93C will not respond to a normal SCSI 
selection or reselection until after a valid selection or 
reselection phase has lasted for more than four milliseconds. 
Second, the AIC-33C93C changes its interpretation of the 


Time-out Period register so that the maximum selection and’ ~ 


reselection time-out is on the order of four milliseconds.. 
These timings stay in effect until the AIC-33C93C is reset. 


7.7.11 Enable SCAM Selection (2D hex) 


The Enable SCAM Selection command enables the AIC- 
33C93C to respond to a SCAM selection. Resetting the device 
disables the response to SCAM selection. 


7.8 Simple Level II Commands 


7.8.1 Select-with-ATN (06 hex) 


Select-with-ATN, valid only in the disconnected state, 
instructs the AIC-33C93C to select a target. Before issuing 
this command, the host should write the SCSI Bus ID of the 
target device into the DESTINATION ID register. The Select- 
with-ATN command causes the AIC-33C93C to begin bus 
arbitration. If another device selects or reselects the AIC- 
33C93C during arbitration, the Select-with-ATN command 
aborts and a “service required” interrupt (8x hex) will occur. 


Should the AIC-33C93C win the arbitration, it asserts SEL 
and ATN, places the target and initiator Bus IDs on the SCSI 
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data bus, and then negates BSY. At this time, a time-out 
sequence begins, its length determined by the value in the 
TIMEOUT PERIOD register. If the target does not respond 
with BSY within the allotted time, the AIC-33C93C begins a 
selection abort sequence as described in the Abort command 
description. If the target has not responded by the end of this 
sequence, the Select-with-ATN command terminates. If the 
target responds before the time-out period has elapsed or 
before the selection abort sequence completes, the AIC- 
33C93C negates the SEL signal, enters the connected-as-an- 
initiator state, and generates a “successful completion” 
interrupt. 


A successful abort of Select-with-ATN, either through a time- 
out or through the Abort command, leaves the AIC-33C93C 
disconnected from the SCSI bus and results in a 
“paused/aborted” interrupt. 


7.8.2 Select-without-ATN (07 hex) 


The Select-without-ATN command is identical to the Select- 
with-ATN command except that ATN is not set during the 
Selection Phase. 


7.8.3 Reselect (05 hex) 


The Reselect command is identical to the Select-without-ATN 
command except that the I/O signal is asserted upon 
completion of the Arbitration phase. Successful completion of 
the Reselect command results in the AIC-33C93C being 
connected as a target. 


7.8.4 Receive (10-13 hex) 


The four Receive commands---Receive Command, Receive 
Data, Receive Message Out, and Receive Unspecified Info 
Out---differ from each other only by the state of the C/D and 
MSG pins and the type of data that is transferred. These 
commands, valid only in the target role, correspond to those 
SCSI information phases where the I/O pins is not asserted; 
the type of the Receive command selected determines the 
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state of the C/D and MSG outputs according to the following 
chart (1=asserted): 


Table 7-1 Receive Command 


Code 


a 
a 


A Receive command will complete or terminate under any of 
the following conditions: 












¢ The host has read the specified number of bytes from the 
DATA register; 


e The AIC-33C93C detects a parity error on one of the 
received data bytes when Halt-on-SCSI-Parity is enabled; 


¢ The AIC-33C93C detects ATN when Halt-on-ATN is 
enabled; 


¢ The AIC-33C93C detects a transfer protocol error; 
¢ The host aborts the Receive command; 
¢ The host issues a Disconnect command; or 


« The AIC-33C93C resets because of a Reset command or 
assertion of MR. 


Any conclusion of a Receive command, except those due to a 
Disconnect command or a Reset, leaves the AIC-33C93C in a 
connected-as-a-target state and the number of bytes not yet 
transferred in the TRANSFER COUNT register. 


In the case of a Receive Data command, the AIC-33C93C 
evaluates the contents of the SYNCHRONOUS TRANSFER 
register. Any offset other than zero selects synchronous 
transfers. The minimum transfer period applies to both 


synchronous and asynchronous transfers. 


The AIC-33C93C also examines the CONTROL register to 
determine what mode of data transfer will occur on the host 
interface. 
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In all other cases, asynchronous transfers occur on the SCSI | In the case of the Send Data command, the AIC-33C93C 


bus, and polled I/O transfers occur on the host interface. 


7.8.5 Send (14-17 hex) 


The four Send commands---Send Status, Send Data, Send 
Message, and Send Unspecified Info---like the four Receive 
commands, differ from each other only by the state of the C/D 
and MSG pins and the type of data that is transferred. These 
commands, valid only in the connected-as-a-target state, 
correspond to those SCSI phases where the I/O pin is 
asserted; the type of Send command selected determines the 
state of the C/D and MSG outputs according to the following 
chart (1=asserted) 


Table 7-2 Send Commands 


Send Command Op 
a 


A Send command will complete or terminate under any of the 
following conditions: 









¢ The initiator has acknowledged receipt of the specified 
number of bytes; 


« The AIC-33C93C detects a parity error on one of the 
received data bytes when Halt-on-Host-Parity is 
enabled; 


¢ The AIC-33C93C detects ATN when Halt-on-ATIN is 
enabled; 


« The host aborts the Receive command; 
¢ The host issues a Disconnect command; or 


¢ The AIC-33C93C resets because of a Reset command 
or assertion of MR. 


Any conclusion of a Send command, except those due to a 
Disconnect command or a Reset, leaves the AIC-33C93C in a 
connected-as-a-target state and the number of bytes not yet 
transferred in the TRANSFER COUNT register. 
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evaluates the contents of the SYNCHRONOUS TRANSFER 
register. Any offset other than zero selects synchronous 
transfers. The minimum transfer period applies to both 
synchronous and asynchronous transfers. The AIC-33C93C 
also examines the CONTROL register to determine what mode 
of data transfer will occur on the host interface. 


In all other cases, asynchronous transfers occur on the SCSI 
bus, and polled I/O transfers occur on the host interface. 


7.8.6 Transfer Info (20 hex) 


The Transfer Info command allows the host to send and 
receive data, command, status, and message information 
when operating in the connected-as-an-initiator state. 


The first REQ assertion following connection as an initiator 
results in a “service required” interrupt. The processor should 
examine the SCSI STATUS register to determine the type and 
direction of information transfer requested by the target, and 
then issue a Transfer Info command in response. The AIC- 
33C93C will also generate an interrupt each time the target 
device requests a new type of information transfer phase. 


The processor either should initialize the TRANSFER 
COUNT register prior to issuing this command or issue the 
command with the SINGLE BYTE TRANSFER bit in the 
COMMAND register set. Also, if responding to a request for 
a Data phase, the processor should set the DMA MODE 
SELECT bits in the CONTROL register and specify the offset 
and transfer period in the SYNCHRONOUS TRANSFER 
register before issuing the Transfer Info command. 


Behavior of the DATA BUFFER READY status bit during 
Transfer Info depends upon the direction of the transfer. 
When the bytes move from the initiator to the target, i.e. an out 
phase, the DATA BUFFER READY bit is set whenever the 
FIFO can accept additional data from the host. When the 
transfer proceeds in the opposite direction, DATA BUFFER 
READY set indicates that the FIFO contains data available for 
the host to read. 


The Transfer Info command normally terminates or pauses 
after the specified number of bytes has been sent or received. 
For a non-Message-In transfer, the AIC-33C93C will generate 
a “successful completion” interrupt after the target asserts 
REQ to begin a new phase. For a message-in transfer, the AIC- 
33C93C does not wait for the next phase but instead leaves 
ACK asserted and generates a “paused/aborted” interrupt. The 
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processor can then assert ATN if it intends to reject the 
message before negating ACK. 





The Transfer Info command may terminate for a number of 
different reasons which are listed below: 


¢ The host issues a Disconnect command; 


* The AIC-33C93C resets in response to the assertion of MR 
or the Reset command; 


¢ The target negates the BSY signal; 


¢« The target unexpectedly changes phase, i.e. before the 
specified number of bytes have been transferred; or 


¢ The incoming data has a parity error and the corresponding 
halt-on-parity-error bit is set. 


The Disconnect command, the hard and soft resets, and the 
negation of BSY will leave the AIC-33C93C in a idle, 
disconnected state, and in these cases, the value in the 
TRANSFER COUNT register will not accurately reflect the 
number of bytes that did not transfer across the SCSI interface. 
Except for the issuance of the Disconnect command, these 
occurrences will result in an interrupt. 


The AIC-33C93C checks for a parity error on each byte it 
receives however, for synchronous transfers, the internal 
microcontroller will not recognize an error until the transfer 
reaches a 4096-byte boundary. The response to the parity 
error, furthermore, depends upon the direction of the transfer. 
If the parity error occurs on received SCSI data, the AIC- 
33C93C will halt the SCSI interface, leaving ACK asserted to 
halt the target, and generate a “terminated” interrupt once the 
host has flushed any remaining bytes from the FIFO. 
Similarly, 1f the error occurs on data received on the host 
interface, the AIC-33C93C will halt the host interface and 
generate a “terminated” interrupt after any bytes remaining in 
the FIFO are flushed to the SCSI bus; the ACK signal, 
however, will not remain asserted. In both cases, the 
TRANSFER COUNT register will indicate the number of 
bytes that did not successfully transfer to or from the target. 





If it detects a parity error but the appropriate halt-on-parity- 
error bit is not set, the AIC-33C93C will indicate the error by 
setting the PARITY ERROR bit in the AUXILIARY STATUS 
register but will not terminate the Transfer Info command. 


An unexpected phase change will cause a “terminated” 
interrupt, and as in the case of a parity error, the TRANSFER 
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COUNT register contains the number of bytes yet to be 
transferred. If an unexpected phase change occurs during a 
SCSI synchronous transfer, the host should test the PARITY 
ERROR bit in the AUXILIARY STATUS register, as the 
phase change most likely occurred before the internal 
microcontroller recognized the parity error. In_ the 
asynchronous case, the AIC-33C93C stops on the byte with 
the error; therefore, it will always detect a parity error before 
a phase change in this mode. 


Note if this command is used in Message In phase, the 
COMMAND PHASE register will contain 00 at the 
completion of its execution. 


7.8.7 SCAM Select (2E hex) 


The SCAM Select command causes the AIC-33C93C to 
perform a SCAM selection. The setting of the SINGLE 
BYTE TRANSFER bit determines whether the AIC-33C93C 
behaves as a level 2 SCAM slave device (SBT=1) or as a level 
1 SCAM master device (SBT=0). 


The AIC-33C93C will arbitrate for the bus upon detecting the 
bus free condition. If acting as a SCAM master, it will arbitrate 
with an ID; if acting as a SCAM slave, it will arbitrate without 
an ID. If it loses arbitration, the AIC-33C93C will release all 
SCSI signals and will wait for the bus free condition before 
beginning the process over again. Once the AIC-33C93C has 
won arbitration, it will proceed with SCAM selection. 


The length of the SCAM selection phase is determined by the 
value in the Time-out Period register. (With a 20 MHz input 
frequency, the value of the Time-out register equals the 
SCAM selection time in milliseconds.) 


The AIC-33C93C will generate an interrupt, upon completion 
of the selection attempt. If a SCAM master is present, i.e. C/D 
is asserted, the AIC-33C93C will generate a 12 hex interrupt 
and will be in the Connected-as-a-SCAM-device §state.; 
otherwise, the AIC-33C93C will generate a 17 hex interrupt 
and will be in the Disconnected state. 


7.8.8 SCAM Transfer (2F hex) 


The SCAM Transfer command is valid only in the Connected- 
as-a-SCAM-device state. It causes the AIC-33C93C to 
perform a SCAM transfer cycle using the data stored the SCSI 
Data Bus register. The latched data is returned via the SCSI 
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Data Bus register. For both the data to be sent and the latched | The AIC-33C93C begins the Select-and-Transfer command 


data, only the five least-significant bits of the register are valid. 


The AIC-33C93C samples C/D before performing a transfer, 


and if it detects that C/D has been released, it will terminate 


the command with a SCAM-Disconnect-Occurred interrupt 
and release all SCSI lines. The AIC-33C93C will be in the 
Disconnected state. 


If C/D is asserted, the AIC-33C93C will perform the transfer 
and then generate a Successful-SCAM-Transfer-Cycle 
interrupt. The AIC-33C93C will be in the Connected-as-a- 
SCAM-device state. 


7.9 Combination Level II Commands 


7.9.1 Select-and-Transfer (08 and 09 hex) 


The Select-and-Transfer commands greatly reduce the host or 
local processor interrupt-handling burden by enabling the 
AIC-33C93C’s internal microprocessor to manage the low- 
level SCSI protocol. Use of these command may result in as 
few as one interrupt per SCSI operation. Select-and-Transfer 
commands, used when in an initiator role, typically consist of 
at least the following SCSI phases: an Arbitration phase, a 
Selection phase, a Command phase, a Status phase, and a 
Command-Complete Message phase. These commands 
optionally include Data and additional Message In phases. 


The Select-and-Transfer commands expect the target to follow _ 


a certain sequence of SCSI bus phases, and any deviation 
from this expected protocol results in a “terminated” interrupt. 
As the different phases complete, the AIC-33C93C updates the 
COMMAND PHASE register, so upon termination of the 
command, the host processor may examine this register to 
identify the cause of the termination and the state of the SCSI 
operation. 


The two Select-and-Transfer commands differ from each 
other only by whether or not the AIC-33C93C asserts ATN 
pin during the Selection phase. The ability to assert ATN 
during Selection supports the SCSI message protocol which 
calls for an Identify Message Out phase following the 
selection. This is mandatory for SCSI-2 compliance. When 
executing a Select-with-ATN-and-Transfer command, the 
AIC-33C93C expects the target to request a Message Out 
phase immediately following selection, whereas for a Select- 
without-ATN-and-Transfer command, it expects the target to 
begin the Command phase once selection completes. 


AIC-33C93C Data Sheet 


by arbitrating for the bus and selecting a target just as during a 
Select command. If the target does not respond before a time- 
out occurs, the Select-and-Transfer command halts and 
generates an interrupt. 


Failure to complete the Selection phase is also indicated by 
the fact that the COMMAND PHASE register contains all 
zeros. If the selection is successful, no interrupt is generated, 
and the COMMAND PHASE register will be set to a 10 hex. 


After completing the Selection phase, the AIC-33C93C 
begins a Message Out phase if ATN has been asserted or a 
Command phase if not. When the target requests a Message 
Out phase, the AIC-33C93C responds by automatically 
sending an Identify message byte, which it generates by 
exclusive-ORing the contents of the TARGET LUN register 
with 80 hex if the ENABLE RESELECTION bit in the 
SOURCE ID register is reset or with CO hex if the bit is set. 
After it has sent the Identify message, the AIC-33C93C will 
set the COMMAND PHASE register to 20 hex. 


Normally, bit 6 of the Identify message mirrors the state of 
the ENABLE RESELECTION bit; however, the host may 
occasionally wish to allow the AIC-33C93C to respond to a 
reselection attempt but not enable target disconnects during 
another SCSI operation. Therefore, when reselections are 
enabled, setting the DISCONNECTS OK bit of the TARGET 
LUN register allows the AIC-33C93C to respond to 
reselection but results in an Identify message byte which does 
not enable target disconnects. 


Following the Identify message out, if bits 3 or 4 of the 
DESTINATION ID register specify a tag message and if ATN 
is asserted, the AIC-33C93C expects the target to request the 
first byte of a tag message. It responds to this request by 
sending the selected tag message code and incrementing the 
COMMAND PHASE register. The AIC-33C93C now expects 
the target to ask for the second byte and services this request 
by sending the contents of the QUEUE TAG register and 
incrementing the COMMAND PHASE register to 22 hex. 


The AIC-33C93C expects a Command phase to follow the 
Message Out phase or, if ATN is not asserted during selection, 
the Selection phase. The AIC-33C93C obtains the SCSI 
command from the internal COMMAND DESCRIPTOR 
BLOCK registers and sends either six, ten, or twelve bytes of 
command information depending on the first byte of the SCSI 
command. The Select-and-Transfer commands support Group 
0 (6-byte CDB), Group 1 (10-byte CDB), and Group 5 (12- 
byte CDB) SCSI commands. The length of any other 
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command defaults to six bytes unless advanced mode is | LUN register. If it does not match, the AIC-33C93C will 


enabled (see 7.3.1). The COMMAND PHASE register, set to 
30 hex before the first Command byte is sent, increments with 
each byte transferred, so for a twelve-byte CDB command, 
the COMMAND PHASE register will contain 3C hex when all 
bytes of the CDB have been transferred. 


After the Command phase, the AIC-33C93C anticipates a 
Data phase if the TRANSFER COUNT register contains a 
non-zero value, a Status phase if this register contains zero, or, 
in either case, a Message In phase if the ENABLE 
RESELECTION bit is set and the DISCONNECTS OK bit is 
not. The AIC-33C93C assumes a pending disconnection if the 
target requests a Message In phase. Thus, when enabled, the 
AIC-33C93C expects to receive either a Save-Data-Pointer 
message (02 hex) or a Disconnect message (04 hex). If a 
message byte has a parity error and the HALT on SCSI 
PARITY ERROR bit is set or if the target sends an 
unsupported message, the AIC-33C93C will generate a 
“terminated” interrupt, alerting the processor of this fact and 
allowing it to retrieve the message byte via the Transfer Info 
command. 


Reception of a correct Save-Data-Pointer message results in a 
‘“paused/aborted” interrupt, terminating 
Transfer command with the COMMAND PHASE register set 
to 41 hex. The processor can then save the SCSI data pointer 
before resuming the Select-and-Transfer command. 


A Disconnect message, on the other hand, will not cause an 
interrupt; instead, command execution continues with the 
COMMAND PHASE register set to 42 hex and with Bus Free 
as the next expected phase. The AIC-33C93C updates the 
COMMAND PHASE register to 43 hex when the target 
actually disconnects and, if the INTERMEDIATE 
DISCONNECT INTERRUPT bit is set, suspends the Select- 
and-Transfer command with an 85 hex interrupt. If, however, 
the INTERMEDIATE DISCONNECT INTERRUPT bit is 
reset, the AIC-33C93C sits in an idle state, waiting for the 
target to reconnect. Reselection by the original target 
generates no interrupt and increments the COMMAND 
PHASE register to 44 hex; reselection by a different target 
will cause a “terminated” interrupt. In advanced mode, this 
interrupt will not occur until the AIC-33C93C has also 


the Select-and- — 


received the Identify message from the target and placed the — 


~ Jogical unit number in the TARGET LUN register. _ 


Following the original target reselection, the AIC-33C93C 
expects an Identify Message In phase from the target. This 
single-byte message should be of the binary form: 10r0Ottt, 
where r and ttt match the corresponding bits in the TARGET 
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interface; and the DMA MODE SELECT bits in the 


generate a 4F hex interrupt. The Identify message must be read 
out from DATA register. Failure to do so may result in the 
transfer count mismatch in the subsequent data phase. See 
sections <Angle>6.2.18 on page 19 and <Angle>7.5 on page 
22 for more details. Successful completion of this phase 
results in the COMMAND PHASE register being updated to 
45 hex or 70 hex depending upon whether or not a tag message 
is expected as deduced from the settings of bits 3 and 4 of the 
DESTINATION ID register. 


The target, in the latter case, should send a SIMPLE QUEUE 
tag message immediately after the Identify message. Upon 
receiving and validating the message byte, the AIC-33C93C 
increments the COMMAND PHASE register and awaits the 
second message byte from the target. When it receives this 
byte, the AIC-33C93C sets the COMMAND PHASE to 45 
hex and then compares the byte to the contents of the QUEUE 
TAG register. If the two values match, command execution 
proceeds; if the two values differ, the AIC-33C93C stores the 
received byte in the QUEUE TAG register, generates a 
“Different Process Reselected” interrupt (26 hex) and 
terminates the Select-and-Transfer command. 


In case the target send out a non-simple queue tag message (a 
SCSI Interlocked Protocol violation) or a message other than 
queue tag, the AIC-33C93C will generates a 4F hex interrupt 
(unexpected Message In phase - meaning the device is 
confused). If this happens, a Transfer Info command should 
be used to read the message one byte at a time, since you do 
not know the nature and length of the message. It is important 
to perform an explicit Negate ACK operation before repeating . 
the Transfer Info command, or the bus protocol will deadlock. 
Once all the messages are received, you can resume SAT 
command at command phase set at 45 hex, to start data 
transfer phase. 


The AIC-33C93C anticipates a data phase immediately after 
the Command phase or after successfully receiving the proper 
messages after reselection. To handle the Data phase, the 
Select-and-Transfer command effectively performs a Transfer 
Info command. The contents of the TRANSFER COUNT 
register determines the number of bytes to transfer; the value 
in the SYNCHRONOUS TRANSFER register specifies the 
type and minimum period of the transfers on the SCSI 


CONTROL register specify the protocol to follow on the host 
interface. 


Any number of disconnection/reconnection cycles may occur 
during the data transfer so long as the target follows the 
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defined message protocol. The COMMAND PHASE register 
will cycle through the disconnect phases (41-45,70,71) with 
each disconnection and subsequent reconnection until all of 
the data has been transferred, at which point it is set to 46 hex. 
During the data transfer, a disconnection will cause an 
interrupt regardless of the setting of the INTERMEDIATE 
DISCONNECT INTERRUPT bit to allow the host to 
reinitialize the external DMA controller. 


The start of the Status phase, assuming the transfer count has 
reached zero, advances the COMMAND PHASE register to 47 | 
hex. If the status byte has no parity error or if the HALT on 
SCSI PARITY ERROR bit is not set, the internal 
microcontroller places the byte in the TARGET LUN register 
and updates the COMMAND PHASE register to 50 hex. If 
the byte contains an error, a 47 hex interrupt will occur, and 
the command will terminate with ACK asserted. 





The AIC-33C93C expects the target to send a Command- 
Complete message (00 hex) to indicate that the SCSI 
operation has completed. Upon receiving this message, the 
AIC-33C93C sets the COMMAND PHASE register to 60 
hex, and if the ENDING DISCONNECT INTERRUPT bit is 
reset, generates “successful completion” interrupt. The 
processor should then read the TARGET LUN register to 
examine the target status. Another interrupt will occur when 
the SCSI bus goes to the Bus Free state or when the target 
again asserts REQ to begin a new information transfer phase 
(as in SCSI linked commands). Setting the ENDING 
DISCONNECT INTERRUPT bit suppresses the “successful 
completion” interrupt until the target disconnects from the 
SCSI bus. 





Another interrupt will occur when the SCSI bus goes to the 
Bus Free state or when the target again asserts REQ to begin a 
new information transfer phase (as in SCSI linked 
commands). Setting the ENDING DISCONNECT 
INTERRUPT bit suppresses the “successful completion” 
interrupt until the target disconnects from the SCSI bus. 


The following table summarizes the possible values that the 
COMMAND PHASE register can assume during the Select- 
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and-Transfer commands and their meanings relative to 
command termination: 


| Table 7-1 


Cmd y 
No SCSI bus device has been selected. The AIC- 
33C93C is in the disconnected state. 


The target has been selected. The AIC-33C93C 
is now in the connected-as-an-initiator state. 


oa An Identify message has been sent to the target. 
21 


The Tag message code has been sent to the 
target 


Command Termination 





























The Queue tag has been sent to the target 


Command phase has started; no bytes 
transferred. 


Command phase, x bytes have been transferred. 


g 
Gg 
g 
Gg 
g 


Save-Data-Pointer message received. 


Disconnect message received, bus not free. . 


Target has disconnected (SCSI Bus Free) 
following a successful transfer of a Disconnect 
message. The AIC-33C93C is now in the 
disconnected state. 


The AIC-33C93C has been reselected by the 
target with a SCSI bus ID which matches the 
value in the DESTINATION ID register. The 
AIC-33C93C is now in the connected as an 
initiator state. 


The AIC-33C93C has received an matching 
Identify message and, if expected, a matching 
Tag message from the target. 


The number of bytes specified in the 
TRANSFER COUNT register have been 
transferred to or from the target during the Data 


The target has begun a Receive Status phase. 


The AIC-33C93C has successfully received a 
Status byte from the target and stored it in the 
TARGET LUN register. 
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Table 7-1 
Cmd ‘ 
60 | The Phe ATC S3CO3C his succesehillyrecewveda | 33C93C has successfully received a 
Command-Complete message from the target. 


The AIC-33C93C has received an Identify 
message from the target, and the Logical Unit 
Number matches the value in the TARGET 
LUN register. A tag message is expected. 


71 The AIC-33C93C has received a Simple-Queue 
Tag message. . 


The host processor may resume a_ Select-and-Transfer 
| sequence by issuing the command when the AIC-33C93C is 
in the Connect-as-an-initiator state. When resuming the Select- 
| and-Transfer, the AIC-33C93C examines the COMMAND 
PHASE register to determine where to restart execution of the 
command. This feature, in conjunction with the 
INTERMEDIATE DISCONNECT INTERRUPT bit, supports 
multi-threaded or overlapped I/O on the SCSI bus. 


Command Termination (Continued) 




















The following table briefly describes the valid settings of the 
COMMAND PHASE register when resuming a Select-and- 
Transfer command: 


| Table 7-2 


Cmd Resuming Select-and-Transfer Cmd 
Phase 


ag Resume after target selection is complete. 


nfs 


Resume after Identify message out. Command 
or message phases are expected; an implied 
Negate ACK occurs. 


22 Resume after Tag message out. Command phase 
is expected; an implied Negate ACK occurs. 
Resume when Command phase has begun (REQ 
asserted). 


Resume after Command phase or after a Save- 

Data-Pointer message. Data, Status, or Message 

| In phases are expected: An implied Negats ACK 
occurs. 


42 Resume to complete Disconnect Message In; an 
implied Negate ACK occurs. 


Select-and-Transfer Command 
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Resuming Select-and-Transfer Cmd 
Phase 
Resume after reselection by a target. An 
Identify Message In expected. 


Resume to transfer more data in a data transfer 
phase. May expect Status or Message In as well. 
An implied Negate ACK occurs. 


46 Resume after the Data phase has completed, 
expecting Status phase or a Save-Data- 
Pointer/Disconnect Message In phase. An 
implied Negate ACK does NOT occur. 

50 Resume to complete a Status phase; an implied 
Negate ACK occurs. 

Resume to complete a Command Complete 
message from the target; an implied Negate 
ACK occurs. 

70 Resume to receive a Simple-Queue Tag 

message. An implied Negate ACK occurs. 


7.9.2 Reselect-and-Transfer (OA and OB hex) 


Select-and-Transfer Command (Continued) 





























The Reselect-and-Transfer commands consist of the Reselect- 
and-Receive-Data and the Reselect-and-Send-Data 
commands. These commands cause the AIC-33C93C to 
execute certain common SCSI bus phase sequences as a target 
following a Reselection phase. These phases, determined by 
which command is sent and the setting of the ENDING 
DISCONNECT INTERRUPT bit in the CONTROL register 
and the SCC bit in the DESTINATION ID register, are 
summarized below. Refer to the descriptions of the Send- 
Status-and-Command-Complete and Send-Disconnect- 
Message commands for details on those sequences. 


* — Reselect-and-Receive command, EDJ=0, and SCC = don’t 
care: 
. ©  Reselection phase; 
e« Send Message In; 
«Receive Data Out phase; 
¢ Completion interrupt. 


e  Reselect-and-Send command, EDI=0, and SCC = don’t 
care: 
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¢ Reselection phase; 
e Send Message In; 
¢ Send Data In phase; 


¢ Completion interrupt. 


¢  Reselect-and-Receive command, EDI=1, and SCC=0: 
¢  Reselection phase; 
¢ Send Message In; 
* Receive Data Out phase; 


¢ Chain to Send-Status-and-Command-Complete; 


¢ Reselect-and-Send command, EDI=1, and SCC=0: 
¢  Reselection phase; 
¢ Send Message In; 
¢ Send Data In phase; 


¢ Chain to Send-Status-and-Command-Complete; 


¢ — Reselect-and-Receive command, EDI=1, and SCC=1: 
¢ — Reselection phase; 
¢ Send Message In; 
¢« Receive Data Out phase; 


¢ Chain to Send-Disconnect-Message; 


¢  Reselect-and-Send command, EDI=1, and SCC=1: 
¢ —Reselection phase; 
e Send Message In; 
¢ Send Data In phase; 


¢ Chain to Send-Disconnect-Message; 


The Message In phase consists of an Identify message and, if 
bits 3 and 4 in the DESTINATION ID register are not both 
zero, a Simple-Queue Tag message. The commands send the 
contents of the QUEUE TAG register as the second byte of 
the Tag message. 


If the reselection attempt times out during a Reselect-and- 
Transfer command, if ATN is asserted and the HALT on 
ATTENTION bit is set, or if a parity error is detected on a 
incoming data byte and the relevant halt-on-parity-error bit is 
set, the command will terminate with the appropriate status. 
In this case, the COMMAND PHASE register will indicate 
the last successfully completed phase. If these conditions do 
not occur and all phases complete normally, the command 
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will end with a “successful completion” interrupt at this point 
if the ENDING DISCONNECT INTERRUPT bit is reset. 
However, if the bit is set, no interrupt is generated and 
command chaining occurs (as described above). 


The following table summarizes the possible values that the 
COMMAND PHASE register can assume during the Reselect- 
and-Transfer commands and their meanings relative to 
command termination. See other command descriptions for 
additional values that can occur when command chaining is 
used. 


Table 7-3 Command Phase Register 
Cmd : 
OO" | No S@SI bus device lias Been seselected ‘The. SCSI bus device has been reselected. The 
AIC-33C93C is in the disconnected state. 


The AIC-33C93C has successfully reselected 
the initiator. The AIC-33C93C is now in the 
connected as a target state. 


20 The Identify message has been successfully sent 
to the initiator. os 
The requested data transfer has been completed. 


The host processor may resume a Reselect-and-Transfer 
sequence by issuing the command when the AIC-33C93C is 
operating in the connected-as-a-target state. When resuming, 
the AIC-33C93C examines the COMMAND PHASE register 
to determine where to restart the Reselect-and-Transfer 
command. This feature in conjunction with the capability to 
chain to other combination commands allows longer SCSI bus 
sequences to be performed by a single command. 
















The following table briefly describes the meaning of the 
COMMAND PHASE register when resuming a Reselect-and- 
Transfer command: 


Table 7-4 
Cmd 
Phase 
10 Resume after initiator reselection is complete; 
start with Identify Message Out. 


Reselect-and-Transfer Command 













Resuming Reselect-and-Transfer Cmd 
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Table 7-4 


Reselect-and-Transfer Command 










ong Resuming Reselect-and-Transfer Cmd 
Phase 
20 Resume after Identify message out; start with 










data transfer phase. If TRANSFER COUNT is 
zero, no data transfer phase occurs. In either 

case, a chain to another combination command 
can occur if enabled. 


7.9.3 Wait-for-Select-and-Receive (OC hex) 


The Wait-for-Select-and-Receive causes the AIC-33C93C to 
idle until it is selected by an initiator, at which time the AIC- 
33C93C will enter the target mode and automatically request 
message and command information. Optionally, the AIC- 
33C93C will then disconnect if it receives a SCSI read 
command. Use of this command therefore eliminates the 
interrupts which normally occur after selection and after each 
subsequent SCSI bus phase and minimizes bus-connect time 
during SCSI read commands. 


If the initiator asserts ATN during the Selection phase, the 
AIC-33C93C first executes an implied “Receive Message Out” 
command to get the Identify message and the Tag message, if 
any, from the initiator. The AIC-33C93C stores the Identify 
message byte in the TARGET LUN register; it encodes the Tag 
message code into bits 3 and 4 of the DESTINATION ID 
register and places the queue tag into the QUEUE TAG 
register. Normally, the Wait-for-Select-and-Receive command 
rejects an Identify message with the LUNTAR bit set; 
however, issuing this command with the SINGLE BYTE 
TRANSFER bit in the COMMAND register set allows the 
AIC-33C93C to accept an Identify message for a target 
routine. 


The AIC-33C93C executes an implied “Receive Command” 
following the Selection phase or Identify Message In phase 
and stores the SCSI command information in the CDB 
registers. It determines the number of command bytes to 
request from the SCSI group code in the first byte of the CDB. 


At this point, a “successful completion” interrupt normally 
will occur. to allow- the local-processorto- interpret-the SCSI 
CDB. However, by setting the ENDING DISCONNECT 
INTERRUPT bit prior to issuing a Wait-for-Select-and- 
Receive command, the host enables the AIC-33C93C to 
perform an automatic disconnect when it receives a SCSI read 
command. Thus, when the ENDING DISCONNECT 
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INTERRUPT bit is set and the lst CDB byte received 
contains a six, ten, or twelve-byte read command code, the 
AIC-33C93C will suppress the interrupt and chain to the 
Send-Disconnect-Message command. Completion of this 
sequence causes an interrupt and normally indicates a 
transition to the bus free condition. Refer to the Send- 
Disconnect-Message command description for more details. 


If the message or command information received from the 
initiator is invalid, the Wait-for-Select-and-Receive command 
will be terminated and the appropriate status reported. As 
usual, the COMMAND PHASE register will indicate which 
phases of the command completed before the error condition 
occurred. 


The following table summarizes the possible values that the 
COMMAND PHASE register can assume during the Wait-for- 
Select-and-Receive command and their meanings relative to 
command termination. See other command descriptions for 
additional values that can occur when command chaining is 
used. 


Table 7-5 Wait-for-Select-and-Receive Command 


The AIC-33C93C has not been selected. The 
AIC-33C93C is in the disconnected state. 


The AIC-33C93C has been successfully 
selected by the initiator. The AIC-33C93C is 
now in the connected-as-a-target state. 


The AIC-33C93C has received a message byte 
(Identify) from the initiator. The TARGET LUN 
register holds the byte. 


The AIC-33C93C has received a message byte 
(Tag code) from the initiator. The QUEUE TAG 
register contains the byte. 


The AIC-33C93C has received a message byte 
(Queue Tag) from the initiator. The QUEUE 
TAG register contains the byte. 


The AIC-33C93C is ready to begin Command 
phase. The SCSI bus phase lines and REQ have 
not been asserted. 
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Cmd 


T 31 | ‘The AIC-33C93C has transferred one command _ AIC-33C93C has transferred one command 
byte from the initiator. The SCSI STATUS may 
indicate the need for the host to load the 
command size into the OWN ID register. 


3x The AIC-33C93C has transferred x command 
bytes from the initiator. 


A “paused/aborted” interrupt in conjunction with command 
phases 20 and 21 indicate that the respective message byte 
was not valid. A parity error in the Identify message results in 
the appropriate interrupt and the COMMAND PHASE 
register set to 10 hex. This combination allows the host to retry 
the transfer by merely reissuing the command to resume the 
operation from the proper phase. A parity error in the other 
two message bytes results in a command phase of 21 or 22, 
indicating which byte contained the error. 


Wait-for-Select-and-Receive Command 








The host processor may resume the Wait-for-Select-and- 
Receive command by issuing the command when the AIC- 
33C93C is operating in the connected-as-a-target state. When 
resuming this command, the AIC-33C93C examines the 
COMMAND PHASE register to determine where to restart the 
Wait-for-Select-and-Receive command. This feature, in 
conjunction with the capability to chain to other combination 
commands, allows longer SCSI bus sequences to be executed 
by a single command. 


The following table briefly describes the meaning of the 
COMMAND PHASE register when resuming a Wait-for- 
Select-and-Receive command: 


Table 7-6 Wait-for-Select-and-Receive Command 


Resuming Wait-for-Select-and-Receive Cmd 


Resume after selection by the initiator is 
complete. Start with Identify Message Out if 
ATN is asserted; otherwise, start with Command 
phase. 


Cmd 
Phase 


Resume after a Message Out; check the received 
message in the TARGET LUN register for a 
valid Identify message. 
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Table 7-6 Wait-for-Select-and-Receive Command 


oud - Resuming Wait-for-Select-and-Receive Cmd 
Leer 


Resume after Identify message verified. Start 
with Tag Message Out if ATN is asserted; 
otherwise, start with Command phase. 


30 Resume after Identify Message Out. Start with 
Command phase. 


31 Resume after the AIC-33C93C has transferred 
one command byte from the initiator. This 
resume point is used only when an unknown 


group code has been detected in advanced mode 
and the command size has been loaded into the 
OWN ID register. 





7.9.4 Send-Status-and-Command-Complete (OD 
hex) 


The Send-Status-and-Command-Complete command, valid in 
the target role, combines the Status and the Command- 
Complete Message phases used to complete a SCSI operation 
into one command. This command also supports linked SCSi 
operations by optionally sending a Linked-Command- 
Complete message after the transferring the status byte. Bits 
in the CDB12 register corresponding to the standard linked 
command control bits in the CDB control the choice of 
Linked-Command-Complete messages. 


Before issuing this command, the host loads the status byte 
into the CDB11 register and the link control bits from the 
current CDB into the CDB12 register. Note that the bits used 
by the AIC-33C93C are identical in meaning to the SCSI 
standard link control bits. Consequently, the host processor 
may simply load the control byte from the current SCS] 
command into CDB12 to obtain the correct function. As the 
command execution progresses, the COMMAND PHASE 
register will update to indicate the last phase completed. 


The possible sequences caused by this command are as 
follows: 


¢ CDB12 bit0=0, bitl=don’t care: The status byte in 
CDB11 is sent, followed by a Command Complete 
message (00 hex), followed by a transition to bus free. 
A “successful completion” interrupt now occurs. 
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¢ CDB12 bitO=1, bitl=0: The status byte in CDB11 is 
sent, followed by a Linked-Command-Complete 
message (OA hex). If the DISABLE FEATURE bit in 
the DESTINATION ID register is not set, a chain to 
the command fetch portion of Wait-for-Select-and- 
Receive then occurs to obtain the next CDB from the 
initiator. AIC-33C93C command execution proceeds 
as described for that command. 


¢ CDB12 bit0=1, bitl=1: The status byte in CDB11 is 
sent, followed by a Linked-Command-Complete-with- 
Flag message (OB hex). If the DISABLE FEATURE 
bit in the DESTINATION ID register is not set, a chain 
to the command fetch portion of Wait-for-Select-and- 
Receive then occurs to obtain the next CDB from the 
initiator. AIC-33C93C command execution proceeds 
as described for that command. 


The assertion of ATN when the HALT on ATTENTION bit is 
set, the assertion of MR, or the execution of a Disconnect or 
Reset command will terminate this command. 


The following table summarizes the possible values that the 
COMMAND PHASE register can assume during the Send- 
Status-and-Command-Complete command nd their 
meanings relative to command termination. See other 
command descriptions for additional values that can occur 
when command chaining is used. 


Table 7-7 


Send-Status-and-Command-Complete 
Command 





No operation occurred; typically, ATN was 
found to be asserted. 


Status phase transfer completed. 


Command Complete message transfer 
completed. . 

61 Linked Command Complete message transfer 
completed. 


The host processor may resume the Send-Status-and- 

~Command-Complete command by loading the appropriate 
value into the COMMAND PHASE register prior to issuing 
the command. This feature, in conjunction with the capability 
to chain to other combination commands, allows for a single 
command to invoke longer SCSI bus sequences. 
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Table 7-8 







Commands 


The following table briefly describes the meaning of the 
COMMAND PHASE register when resuming a Send-Status- 
and-Command-Complete command: 


Send-Status-and-Command-Complete 
Command 


Resuming Send-Status-and-Command- 
Complete Cmd 


Resume after status phase. Start with command 
complete message. May chain to command 
fetch if selected to do so. 


Cmd 
Phase 
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7.9.5 Send-Disconnect-Message (OE hex) 


The Send-Disconnect-Message command, a_target-mode 
command, instructs the AIC-33C93C to send a Disconnect 
message and then to deassert the BSY signal, causing a 
logical disconnection of the device from the SCSI bus. Also, a 
Save-Data-Pointer message will precede the Disconnect 
message if the host sets the INTERMEDIATE 
DISCONNECT INTERRUPT bit prior to issuing this 
command. 


The assertion of ATN when the HALT on ATTENTION bit is 
set, the assertion of MR, or the execution of a Disconnect or 
Reset command will terminate this command. The following 
table summarizes the possible values that the COMMAND 
PHASE register can assume during the Send-Disconnect- 


‘Message and their meanings relative to command termination. 


Table 7-9 Send-Disconnect-Message Command 


Meaning 


No operation occurred; typically, ATN was 
found to be asserted. 


a The Save-Data-Pointer message was transferred. 


ae The Disconnect message was transferred. 


The bus free state occurred after the Disconnect 


message was transferred. The AIC- 33C93C i is | 


‘now in the disconnected state. 
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8.0 Electrical Characteristics 


ABSOLUTE MAXIMUM RATINGS 


Voltage on any pin with respect to GND.... -0.5V to +7.0V 


Operating temperature............ccccceesesssesseeeeseseeeeees 0 to 70°C 

Storage temperature ............ cs eeseeseeeeseneseeeeees -55 to +125°C 

POWEF GISSIDALION cicesecetcodsstesnabcastacoccsdncgstoctpevsessesas 500mW 

Input static discharge protection ............. 2,000V pin to pin 
Table 8-1 © DC Operating Characteristics 


I 
IOI 
Iq2 
ViH 
VIL 
VIHS 
VILS 
VIHYS 


fipetaaaee Pe [Ver 
sts Cup cage GnaewrPowero || [wa | Vour= Verb 
[oupateaeecmeSae) || | a _| Yours Ver 
pig Vtg nonscipag [29 | |v 

party Wage atti) |_| os |v 
[csipstpurin se P| 
[Ssipstpctow ngs Yt | 
Se 


— AND driver pins* output high current DC Limit | | 20 | ma VOS 2 2.00V 


Vou 
VoL 
Voc 
Icc 





SCSI Output Low Voltage (REO, ACK pins) | tae @ ! Ig, = 57.0 mA 
(BSY. SEL,ATN,MSG.C/D,1/0 pins) Ig. = 48.0mA 
npg ig awmsesigng | 3 | | Vi 
Ee 
ec 


a. “AND driver pins” include REO, ACK, SD7 through SDO, and SDP. 
b. Clock frequency at 1/(tcp)min, VCC = VCCyypx, All Outputs Open, All Inputs at negation level, Ta = 25°C 
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9.0 Timing Characteristics 


Timing characteristics are valid over the entire operating temperature (0 to 70 deg. C) and voltage (4.75 to 5.25 Volts) ranges, and 
are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts. All outputs are assumed to have a load 
capacitance of 50 picofarads. Additionally, open-drain outputs DRQ and DACK are tested with 10 mA current source pull-ups as 
loads. 








9.1 General 


9.1.1 Special Circumstances 


The SCSI asynchronous timings, furthermore, assume that the minimum assertion and deassertion times specified for the chosen 
transfer period have been met. For example, with a transfer period of four, the AIC-33C93C, clocked at 20MHz, acting as a 
target, will assert REQ for at least 200 ns. If the initiator takes more than 200 ns from the leading edge of REQ to assert ACK, 
then the AIC-33C93C will release REQ within 175 ns (9.3.7 talrh). However, if the initiator responds with ACK within 200 ns of 
REQ, the AIC-33C93C may not meet the specification in order to meet the programmed transfer period. 





These timings, moreover, apply only during a burst and assume that the FIFO has space or data available to allow the burst to 
continue. For instance, 9.3.6 trlal for the first byte of a new phase or of a 4096-byte burst will depend on the time needed by the 
AIC-33C93C and possibly the host microprocessor to respond to the new phase or to set up for the next 4096-byte block. Clearly, 
the AIC-33C93C can not meet the 175 ns timing in these situations. In addition, the internal microcontroller controls the 
handshaking of messages bytes, like the Identify and Disconnect messages, during execution of the combination commands, and 
again, in these cases, the AIC-33C93C will not meet the asynchronous transfer timings given in the following tables. 


9.1.2 SCSI Transfer Phase Timings (How to deal with T cyc Specification) 


Many of the timing parameters that follow are defined in terms of an internal transfer clock cycle time Tcyc. The cycle time 
depends upon the input clock frequency, the clock divisor selected, and, for synchronous transfers and if the input clock 
frequency is 16 MHz or greater, the setting of the FAST SCSI SELECT bit in the SYNCHRONOUS TRANSFER register. 
Section 6.2.12 provides the details on calculating Tcyc for a given set of these parameters. For normal SCSI transfers, the 
resulting clock has a frequency from 4 MHz to 5 MHz; for fast SCSI transfers, the frequency falls in the range from 8 MHz to 10 


MHz. For non-transfer timings, such as those pertaining to arbitration and bus release, Tcyc corresponds to the value for 
normal SCSI transfers. 


When Synchronous transfer is chosen with the FAST SCSI SELECT bit set, the Tcyc parameter not only affects the SCSI bus 


side, but also the host side DMA timings. Care should be taken at the time of the application design, so the AIC-33C93C 
synchronous timing will not violate the host side hardware timing requirements. 
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9.1.3 Table Entry Conventions 


¢talbh? | A low setup time prior to B high? Lake OE | | 


a. Symbolic name for the timing. The convention is: t(pin1)(hlvli)(pin2)(lhivii) _ (mode) 
where (pin1),(pin2) are 1 character designation of pins, 
(ilhlvid) are code for the reference edges; 
I: Low going edge 
h: High going edge 
v: The state becomes valid 
i: The state going invalid 
(mode) is an associated operation mode of the de- 
vice for the specification. 
e.g., hri = Host Read Indirect, 
dw = DMA Write, etc. 





* For example, tclwl_hw might mean “In the Host (direct) Write operation, the time between CS pin going low to WE 
pin going low”. 


¢ The timings with mark are only functionally tested. The min/max value are guaranteed by design. Exact timings 
may depend on a given applications and circumstances. 


b. Textual description of the timing. It describes whether the timing is setup time, hold time, input to output, output to 
input delay time, input or output relative time, etc. 


c. Timing classification code: R is a requirement for the part of user, for the device to function correctly. 
Minimum specification means “must be at least this much for normal 
operations”. 

Maximum specification means “must not take more than this to expect 
the specified behavior”. 
S is a guaranteed I/O timing for the device under proper operating 
condition. 
Minimum specification means “‘it takes at least this much time”. 
Maximum specification means “it responds within this much time”. 


d. The timings are specified in either (a) absolute scale (ns, us, etc.) or (b) clock cycle sliding scale (Tcyc). In type 


(b) specification, “2-10ns Tcyc”’ means “2 transfer clock cycle time minus 10 ns”. Refer to section 6.2.12 for 
the definition of Tcyc. 
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9.1.4 AC Timing Test Conditions 


vih 
Input Signal 2.0V ae Vil 
Vowtsee sec 8.0) 
Output Signal Vol Vay (see sec 8.0) Voh 
Input Bus Signal 













ie Valid data is 


on the bus 


ma The data becomes 


: ; The bus contains 
invalid 


invalid data. 
(Typically complement of 


# # 
oe Vioad Vioad valid data for test purpose) 
—_ Data output is | The device tri-states.** 





valid. 


The device now 
drives.* 


The data becomes invalid. 


Vioad" 


Open Drain Output Ne = : = Driver inactive; pulled up high 
Driver active; pulled down low 


For the AC timing testing purpose, the input signals are overdriven between vil and vih as specified below. The timing are 
measured at Vj=0.8V and Vyy= 2.0V (inputs), Vy = Vol and Vyj= Voh (outputs) as specified in the table below. 


*The device is defined as “driving” when the voltages moves from Vload (natural hold voltage of the load) by 150mV. 


**The device is defined as “tri-stated” if the signal level moves from VOH/VOL by 150mV under specified load condition (Cy, 
Jou lov). 


*Vload for all host side pins are at 1.5V, and all SCSI side pins are 3.3V. 


Table 9-1 Test Voltages sorted by Pins 


a eo 
RE, WE, [7.0], DP, INTRQ | 04 | 24 | 08 | 20 | Full Tri-State Drivers 


CE 
[aRsE mre [at [i [ea 
Ee 
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9.2 Processor / DMA Interface 


9.2.1 Clock 






Characteristic 






Clock Period 


Clock high time 






Clock low time 





tcp 
le tch —»| - tc] 
CLK 





(in) 


9.2.2 Master Reset 





Characteristic 










R pulse width 





gg oes = 





(in) 
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9.2.3. Processor Write (Indirect Addressing) 


SC 
wae [AempamemreWEme SS RO] 
SoLhei [Sopine mre Ww SC RT 
vehi [WEpatewaw ——SSSSCS~sr PP 
SAW [Den smpiineneorw Ener ————SSSSC~sRC | 
waits [ADO neaerWEM® SR 
wich oi [EShokineatrWEnen——SS*d LP 
SS 
who [WEREeevineste Wine «| | 


r 






— tavwl 





fs a Valid Register Address 20 + tahal min 
twhc 

cS 

(in) 

WE 


. 
i tdvwh twhdi 
re 


Valid Write Data 
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9.2.4 Processor Read (Indirect Addressing) 


Smo iam S*d RS | Mi | | 
SN 
isi [ESompinepioroREw PR PO] 
whi [REmtewae ——*d | 
ei [Danaidaenyioniew ———SSSSCS~sS 
ch [ShoineaterKEnm CT | 
ei [Dan coputodineateRnap ————SSS~d SS | 
sii [OmtoeisaceteREn® CS | 
cee [REWereoevinesteis ———SS~d RT | 
chibi [ADbolineaterREne ———SSSSC~s | 


na 20 + tahal min 






— tavrl 







AO Ce Valid Register Address Se 

(in) = 

cs 

(in) 

RE tatty 


Valid Read Data 
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9.2.5 Processor Write (Direct Addressing) 


Smet [inne ——SSSC*d RS i | ae | 
cnahw [Auten Seapine ore ALERT] | 
aLiw _[AtieshollneatwaLEtimaie | | S| 
avLhw [Reo inn AlEtaingeae Ww | | | 
cuitw [SseupineraroWEiw ————SSSS~i CCP | 
veh [WEpaewam CP] 
Soh [Dan cup inepir WEN vaSamED | ® |= || 
whch [Steines P| 
Se 


tahal 
le i - twhal 
ALE 


(in) 





DO-7, DP} e Valid Write Data 
(in) 
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9.2.6 Processor Read (Direct Addressing) 


Smo Gane —S*d RS Mi | | 
za [Raion sapimepeALER SR | 
chk [AttowindinwaterALEaigeie® TR | S| 
sin [Peoney tne ALB iegseoREiow SSSR | 
cH [Sseunineniroiin ———SSSCSC~C~—sCRC*C 
ev [mtv CT 
eit om wivacwyioniin ———SSCSC~sdCS 
on [Sines ————SSSCS~—s PP 


tahal i ; 
< > _ trhal 
(in) | 
| tclrl boos 

cs 
(in) 
RE | 
(in) taval talai 








DO-7, DP | > valid Addr © 


(in) (out) 
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9.2.7 DMA Write 


eC 
GvLow _[BRCRopacopamepore Wem = Pe] 
win [WEimuniewan SS SSSSC~iCR | 
why [WERE ecweyinesia WE ————SSS*dP RP | 
srwh tv [Danseupioe ore Epa PL | 
who [BACK linear WEimpunh SSS | || 
what [Dan toner WE ————* | P 
din dv [DRG sonora DACK oan SSS SPO] 









DRQ 
(out) 
tdiwl twhdh 
DACK 
(in) . 
twr twhwl 
WE \ / | \ 
(in) 
’ tdvwh| twhdi 
DO0-D7, DP 
(in) 
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9.2.8 DMA Read 


Smmba_[ iene —SSCSC*d S| | 
aia [ekscapinepiroRn ————SSS—~d | | 
a 
ond [WERE omy ineateREn —————SSS* P| 
sonar [BRCRidineataREni@ ———SSSSSC*d | 
vs [Biase cya DCKenpis SSCs PO] 


DRQ 
(out) 


DACK 
(in) 


RE 
(in) 


D0-D7, DP Valid Data > 


(out) 
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9.2.9 WD-Bus Buffer Write 


Syme [ cerns —*d S| 
WEwmenievin iS 
Wiegeeine SSCS 
WEiwopmcwaas SS PO 
Pancnaivineate WE SS | 
PRO ov WRT diimpeinems S| 8] 
ES o WEphinpetwsestny S| 
WE ewine iow ESimve ———SSSCS~CS 
svow [RCSiovsmpinepiorwWEw ——SC* CS 


tslwv_ww 
two_ww 
twc_ww 
twldv_ww 
twhdi_ww 
tqlsh_ww 
tshwi_ww 


twhsh_ww 


twlql_ww 


tslql_ww 


a. Tp is the Bus Transfer Cycle period specified in the SYNCHRONOUS TRANSFER register (see 6.2.12). 


Timing Characteristics 


e 


nits 
ns 
ns 


Tcyc 


ns 
ns 

Teyc 
ns 
ns 


Tcyc 


DRQ low after WE falling edge? (DMA throttling) Tp- Teye min 
2 Tp - Tcyc - 40 ns max 


DRQ low after RCS falling edge (single byte transfer) Es Z Tp + Tcyc - 85 ns 


b. to guarantee that only one more byte will be transferred. 


48 


(Single byte transfer case) 
DRQ > a; a ene 
"7 tqhsl tsiql | twlql tqish 

— 1 be — aE 4 


| tslwl 
RCS (DACK) 
(open drain out) 















= a 






WE 

(out) 

DO-D7, DP Valid Data Valid Data Valid Data 
oity Nala ere Gand 
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9.2.10 WD-Bus Buffer Read 


Semone «dR | 
SN 
rior [PwatowtineaterKEnah ————SSSCS~dSRCY OP 


triql_wr DRQ low after RE falling edge* (DMA throttle) Tp - Tcyc min 
2 Tp - Tcyc - 40 ns max 


tslql_wr DRQ low after RCS falling edge (single byte transfer) Es 2 Tp + Tcyc - 85 ns 


a. to guarantee that only one more byte will be transferred 


(Single byte transfer case) 
DRQ / \ 


tqhsl tsiql | triql tqlsh | 


tslr] | 
RCS (DACK) 
(open drain out) 
. We tre 7 


(in) 
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9.2.11 Burst DMA Write 


Smo [_____Garsceanthancesse——S«d RS] Mim Ms | Ua 


DRQ 
(out) 


DACK 
(in) 


WE 
(in) 








DO-7, DP 
(in) 
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9.2.12 Burst DMA Read 


A 


<_ triqh + 





out 
we tdirl | _trhdh 


DACK 
(in) 


RE 
(in) 





DO-7, DP 
(out) 
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9.2.13 Interrupt Request 


ce 
DoROsapimepoeREe SR 
pews || 
etROcerincate Een ———SSSC*d S| 






INTRQ 
(out) 


RE \ / 
(in) 


NOTE: This read cycle signifies a read from the SCSI STATUS register. 
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9.3 SCSI Interface 


9.3.1 Arbitration Won 


Characteristic TRS | Min | Max | Units 
BSY, SEL input negation to BSY out assertion | S$ | 12 | 16 | Toye | 
i onmeinwiwDen | sf a ae 
iemienineiimame pe pape fe 


& These timings are microcode driven; exact timing may vary depending on the circumstances. 









2.4 Ws min 





¢— tbhbl 
BSY / (in) \} (out) 






tbls] 





SD{7..0], SDP Valid ID Out 
Igroup Pins* 


Tgroup Pins** 


*Igroup Pins are driven by the initiator; includes ATN, ACK 


**T group Pins are driven by the target; includes /O, C/D, MSG, REQ 
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9.3.2 Selecting a Target (As an Initiator) 


Syma Guanine [ BS] ‘Min | Non] tals] SOSISp 


tsloo SEL out assert to “OR-ed ID” out valid | eS Wt le ae 1.2 ps min 
tovao “OR-ed ID” out valid to ACK, ATN out } s | wo | & | ms | O ns min 
taobh ACK, ATN out valid to BSY out [ACK, ATN out valid to BSY outnegation =| iincnulcters lenin n a ee 90 ns min 


tbhbv BSY out negation to BSY in assertion 400 400 ns min 
200 ms max 
tblsh BSY in low to SEL out high (to Information transfer 
phases) 


& These timings are micro code driven; Exact timing may vary depending on the circumstances. 


(out) / \ Gn) 











BSY 
tbhbv | tblsh + 
SEL 
(out) 
SD[7..0], SDP “OR-ed ID” Valid 


Le tovag | taobh 
AIN \| 
| 


ACK (Active Negation) 


(out) 


Tgroup Pins* 


* Tgroup Pins are driven by the target; includes I/O, C/D, MSG, REQ 
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9.3.3 Response To Selection (As a Target) 


tslbh SEL in assertion (with valid ID) to BSY in negation ake Ove ae 1.29 us min 


tivbh “OR-ed ID” }“OR-ed ID” setup time prior to BSY in negation | time prior to BSY in negation Bete ee trees ee a OE 90 ns min 

tbhbl SEL in assertion, ID valid, and BSY in negation to 400 ns min 
BSY assertion 200 ms max 

tbloi “OR-ed ID” hold }“OR-ed ID” hold time after BSY out assertion | after BSY out assertion }“OR-ed ID” hold time after BSY out assertion | R | 0 | | os | Ons min 

tblsh BSY out asserted to SEL in negated 90 ns min 
(end of Selection phase) | 

tavsh ATN valid input prior to SEL in negate PR foo [fos | - 

tshio | SEL input negate to Tgroup pins valid } s | 100 | & | ons | - 


& These timings are micro code driven; Exact timing may vary depending on the circumstances. 






(Active Negation) 


Tgroup Pins* 
(out) 


*Tgroup Pins are driven by the target; includes I/O, C/D, MSG 
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9.3.4 Reselecting an Initiator (As a Target) 


Timing Characteristics 


tsloo SEL out assertion to “OR-ed ID” output valid PS Be 1.2 us min 
tovio “OR-ed ID” out valid to I/O and Tgroup pins out valid | s | wo | & | ns - 
tiobh Tgroup pins out valid prior to BSY out negate Zee a2 See 90 ns min 


tbhbv BSY out negation to BSY input assertion valid 400 400 ns min 
200 ms max 


tbIsh BSY input assert to |BSY input assert to SEL and BSY out valid. and BSY out valid /BSY input assert to SEL and BSY outvalid = | S| 100 | & | os | 90 ns min 


& These timings are micro code driven; Exact timings vary depending on circumstances. 


BSY (out) 





(out) 


tbhbv ey 






SEL 
(out) 


SD[7..0], SDP 
(out) 


so tiobh 


VO \ 
(out) 


Tgroup Pins* 





REQ (Active Negation) 


*Tgroup Pins are driven by the target; includes C/D, MSG 
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9.3.5 Response to Reselection (As an Initiator) 


Saint Ganecesie «zB |‘Mn | ‘Mn | Unto] SST Spe 


tslbh 
tivbh 
tilbh 


¢tbhao 


¢tavbl 


tbhb! 


¢tbloi 


¢tblsh 


¢tshbh 


SEL in assert prior to BSY input negate PRs Oe UN Sn 1.2 Us min 
“OR-ed ID” setup time prior to BSY input high PR foo | | oas | 90 ns min 


I/O input assertion prior to BSY input high cae a ee 90 ns min 


SEL in low, ID valid, BSY in high to ATN, ACK - 
driving 


Igroup (ATN, ACK) driving to 'Tgroup (ATN, ACK) driving to BSY out assertion —_| out assertion atta ae ee ee 


BSY in high to BSY out low9.3.3 0.4 200 400 ns min 
200 ms max 


|“OR-ed ID” hold time after BSY out assertion ID” hold time after BSY out assertion “OR-ed ID” hold time after BSY out assertion = | R | 0 | fons | O ns min 


BSY out low prior to SEL input high (end of 90 ns min 
reselection phase) 


SEL input high to BSY out high Fs foo | & | ms | Ons min 


& These timings are micro code driven; Exact timings vary depending on circumstances 





tslbh 


tbhbl eases tbIsh + tshbh 


i 
SD[7..0}, SDP < | *oRed ID" valid | > 
(in) 

tbhao ee 
ATN 





(out) | 
tilbh 
1/0 x 
(in) i ae: Sere 
ae (Active Negation) 


AIC-33C93C Data Sheet 57 


SCSI Interface Timing Characteristics 


9.3.6 Receive Asynchronous Information Transfer In (Acting as an Initiator) 


Symbol 
¢tshpc_iar 
tildt_iar 
tpcrl_iar 
tdvrl_iar 
¢trial_iar 
taldi_iar 
talrh_iar 


trhah_iar 


Taser iw ETc | ® | a0 | | _w | OOovmi 


¢#tahpc_iar | Phase change after the final ACK out high oR Oe ch ih tage 3) O ns min 


& These timings may be driven by microcode; Exact timings vary depending on circumstances. 


SEL / le > (inactive) 

. * ~ 
cere eis 
3 — 
(in) 








tildt ivy, etaldiy ¢ > 

SD[7..0], SDP Data input Valid | 

tal |  thah 

tpol pie" pee talth le 

REO ; H i 
(in) 
ACK 
(out) 
AIN 
(out) 


* Phase Pins are driven by Target; include C/D, MSG, I/O 
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Timing Characteristics 


9.3.7 Send Asynchronous Information Transfer In (Acting as a Target) 


SCSI Interface 


¢tshpc_tas |SEL input high (inactive) to Phase pins output valid | S | 100 | & | as | O ns min 
¢tildo_tas | Data output valid delay from I/O output low | s | soo | & | ns | 


tdvr]_tas Data output setup time prior to REQ output low Ee ee SS 25 ns min 
¢tpcrl_tas | Transfer phase valid prior to REQ output low Fs | soo | & | os | 400 ns min 


trlal_tas 
talrh_tas 
taldi_tas 


trhah_tas 


REGoaiorsmpioeniorwACKipaiow | ® | © || = 
Goce neater Kiptiow | |e | ® | = 
Dan cupainvineatarACRmaiow | 8 | > | | = 
Akoya RTs | ® | o ||» 


@tahpc_tas | Phase change after the final ACK high Tea eS 


tahrl_tas 


& These timings are micro code driven; Exact timing may vary depending on the circumstances. 


SEL / shP * (inactive) 

7 * 
(ou) Cy 
a _ 
(out) 







SD[7..0], SDP Data Out Valid 


tpcrl rene talrh sfebleuiy 


REQ 
(out) 
ACK 
(in) 





AIN 


Ons min 
Ons min 
Ons min 
Ons min 
O ns min 


Ons min 


(in) *Phase pins are driven by Target; include C/D, MSG 


AIC-33C93C Data Sheet 
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SCSI Interface Timing Characteristics 


9.3.8 Send Asynchronous Information Transfer Out (Acting as an Initiator) 


& These timings are micro code driven; Exact timings vary depending on circumstances 


SEL / SP * (inactive) 
Ph ins* 
Gin) Pus Transfer Phase 


mJ 
(in) ‘ 






Data Out Valid 


| | trhah, tahpc 
tpcrl $e thane talrh sans eS 


SD[7..0], SDP 





REQ 
(in) 


ACK 
(out) 





ATN 
(out) eerie Sears 
~~~ **Phase pins are driven by Target; include C/D, MSG © 
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Timing Characteristics 


9.3.9 Receive Asynchronous Information Transfer Out (Acting as a Target) 


¢tshpc_tar 
¢ tihdt_tar 
¢tpcrl_tar 
trlal_tar 
tdval_tar 
talrh_tar 
taldi_tar 
trhah_tar 
¢tahpc_tar 


tahr]_tar 


SEL 


SEipaimePeepmoeas | s fm || 
Tis dchyoodantestonboonni | © | | _® |» _ 
Posed pia REGowaiew + S| aw || 
AeKioptiw ar REGouiow «TR | 8 || 
Dan inpiup ine pire ACRpsiow [RS [| 
Gout AKinny +s | © || = | 
Dany interACKinpow ‘|B | | | 
AKipadewsta Ronn +t ® | © || 
Psecmgater intl Rh ———*S | iw || 
AeKiopanprowiKGoan +s |e || = 






i 
i 


i (inactive) 
<tshpg 


: t 


. * : 
ao es Transfer Phase 


VO 
(out) 





SD[7..0], SDP 


REQ 
(out) 


ACK 
(in) 





ATN 
(in) 
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O ns min 
400 ns max 
400 ns min 

Ons min 

12 ns min 

Ons min 

Ons min 

Ons min 


O ns min 
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SCSI Interface 


9.3.10 Receive Synchronous Information Transfer In (Acting as an Initiator) 


Timing Characteristics 


tdvrl_isr Data input setup time prior to REQ input low PR | 5 | | ows | 12 ns min 
tridi_isr Data input hold time after REQ input low 5 Me ae 22 ns min 


rey. ist REQ input cycle time Tcyc 200 ns min 
100 ns min* 


trirh_isr REQ input low pulse REQ inputlow pulsewidth Sl XE 30 ns min 


talah_isr ACK output low pulse width? 1-10ns Teyc 90 ns ua 
30 ns min 

¢tahal_isr | ACK output recovery time? 1-10ns Tcyc 90 ns min 
30 ns min* 


tahpc_isr [Phase change after ACK outhigh =| change after ACK out high knee a me ee Bie 0 ns min 


a. Fast SCSI timing. Applicable to 1OMB/s transfer. 


b. tahal and talah are complementary timings; they always add up to an integral multiple of Tcyc, copending on the 


programmed value in the SYNCHRONOUS TRANSFER register (see 6.2.12). 


i. tdvrl tridi 
nput Valid 






SD[7..0], SDE 


Data Input Valid 








(in) 


-_ pig tahal = 


ACK 
(out) 


AITN 
(out) 


* Phase pins are driven by Target; include C/D, MSG, I/O 
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- trirh —> 
REQ ‘ j \ / 


tahpc 
ies 


Phase Pins* . x 
(in) 


AIC-33C93C Data Sheet 


Timing Characteristics SCSI Interface 


9.3.11 Send Synchronous Information Transfer In (Acting as a Target) 


tdvrl_tss 
tridi_tss 


trirh_tss 


trhrl_tss 


tacyc_tss 


talah_tss 


#tahpc_tss 


Data output setup time prior to REQ output low | S| 1-20ns | | Tey 25 ns min 
Data output hold time after [Data output hold time after REQ output low | output low acme bieers tne A Any OE 35 ns min 


REQ output low pulse width® 1-10ns Tcyc 80 ns wae 
30 ns min? 
REQ output recovery time® 1-10ns Tcyc 80 ns ne 
30 ns min? 
ACK input cycle time Tceyc 200 ns ae 
100 ns min® 
ACK input pulse width 80 ns we 
30 ns min® 


Phase [Phase change after the final ACK high = after the final ACK high ——— ee eo oe Ons min 


a. trirh and trhrl are complementary timings; they always add up to 2 x Tcyc or higher, depending on the programmed 
value in the SYNCHRONOUS TRANSFER register (see 6.2.12). 
b. Fast SCSI timing. Applicable to 1OMB/s transfer. 


SD[7..0], SDP 


REQ 
(out) 


ACK 
(in) 


Phase Pins* 
(out) 





AIN 
(in) 


* — Phase pins are driven by Target; include C/D, MSG, I/O 
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SCSI Interface Timing Characteristics 


9.3.12 Send Synchronous Information Transfer Out (Acting as an Initiator) 


* 


Symbol 
tdval_iss 
taldi_iss 


trcyc_iss 


trirh_iss 


talah_iss 


tahal_iss 


tahpc_iss 


Data output setup time prior to ACK output low | S| 1-25ns | | Toye | 25 ns min 
Data output [Data output hold time after ACK output low time after ACK output low Hane pecan Bon OR 35 ns min 


REQ input cycle time Tcyc 200 ns min 
100 ns min 


ACK output pulse a 1-10ns Tceyc 80 ns rue 

30 ns min*# 

ACK output recovery time 1-10ns Tcyc 80 ns sees 
30 ns min* 


Phase change }Phase change after the final ACK outhigh the final ACK out high jPhase change afterthe final ACK outhigh = | Rf 0 | os Ons min 


a. Fast SCSI timing. Applicable to 1OMB/s transfer. 


trcyc | 
trirh —> 
REQ \ / \ / 
(in) 
“ talah pig tahal “ 

ACK \ y ‘ [i 
(out) 

je ‘aval r taldi 4 


: 
4 


SD{7..0], SDP Data Output Valid Data Output Valid i 


| tahpc 
> 
Phase Pins* x 
(in) 
ATN 
(out) 
Phase pins are driven by Target; include C/D, MSG, I/O | 
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9.3.13 Receive Synchronous Information Transfer Out (Acting as a Target) 


* 


tdval_tsr 
taldi_tsr 


trirh_tsr 


trhrl_tsr 


tacyc_tsr 


talah_tsr 


Data input setup time prior to ACK input low Pe is, Oe |e Bee - 12 ns min 
Data input hold time [Data input hold time after ACK input low ACK input low Sela enon ce 22 ns min 


REQ output low pulse width 1-15ns Tcyc 80 ns a 
30 ns min® 


ACK input riety time Tcyc 200 ns wus 
100 ns min®# 

ACK input low pulse width 90 ns aes 
30 ns min® 


¢tahpc_tsr | Phase change after the final ACK high a Ons min 


a. Fast SCSI timing. Applicable to 1OMB/s transfer. 


trirh >< trhrl 
REQ 
(out) \ j \ / 


tacyc 
talah —> 
ACK \ / \ /\ 
(in) i 
i tdval , p taldi + | 


SD[7..0], SDP Data Input Valid Data Input Valid eo! 


| tahpc. 


Phase Pins* x 
(out) 


ATN 
(in) 


Phase pins are driven by Target; include C/D, MSG, I/O 
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SCSI Interface Timing Characteristics 


9.3.14 Arbitration to Bus Free (Arbitration Lost) 


[Characene SCR | Min | ‘Mex Un 
SEL input low to BSY, Data bus inactive (tri-state) | S| | 6+75ns | Toyo | 










SCSI Spec 


¢tslbh 800 ns max 


BSY (out) (inactive) 





SD[7..0], SDP Valid ID Out 
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Timing Characteristics 


9.3.15 Selection / Reselection Timeout to Bus Free 


snes] | | 
Fimcouoibarocautscens YS | 8 | 
DaabsceandwseCoummin | s | 20 | | ws 
Bonne Tigoppsmse | s | | 0 |» 





#ttadc 





#tdcsh 





¢tshih 


BSY (out) / (inactive) 


(inactive) 








SD{[7..0], SDP 





Tgroup* or { 
Igroup** Pins 


*  Tgroup pins are driven by Target; include /O, C/D, MSG, REQ 


** Tgroup pins are driven by Initiator; include ATN, ACK 
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SCSI Interface Timing Characteristics 


9.3.16 Connected-as-an-Initiator to Bus Free 


Gincre—*dRS Min [| Ua 
BSY input high wo Data bus usta Pose a 






SCSI Spec 






¢tbhdt 1.2 us max 





¢tbhet 





SD[7..0], SDP 
(out) 





Igroup* Pins > 
(out) 


* — Tgroup pins are driven by an initiator, including AT'N and ACK 
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Timing Characteristics 


9.3.17 Connected-as-a-Target to Bus Free 


Ghar —SC*RS | Mn | Max Ua | 
BSY out high to data bus tri-state | S| | 8+75ns | top | 
BSY out high to Tgroup pins tri-state | S| | 8+75ns | top 


BSY / | 








¢tbhdt 





¢tbhet 





(out) 


SD{7..0], SDP 
(out) 


(out) 


*  Tgroup pins are driven by Target; include I/O, C/D, MSG, REQ 
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SCSI Spec 





1.2 us max 





1.2 us max 
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Time-out Period Register (address = 02 hex) 


Appendix A - SCAM Specific Features 


This section describes the differences between the AIC- 
33C93B and the AIC-33C93C products. 


A.0 New and Modified Register Defini- 
tions 


A.l Time-out Period Register (address = 02 hex) 


When SCAM-tolerant timings are enabled, the AIC-33C93C 
will interpret the contents of the Time-out Period Register 
when selecting or reselecting another device according to the 
following equation. 


125T |. X Fron 


per 


register value = 4 


where Tper is the time-out period specified in milliseconds 
and Fjcjx is the input clock frequency in megahertz. 


During a SCAM selection, the contents of this register specify 
how long the selection attempt should last, according to the 
following equation. 

ivr a Fieik 


register value = 
= 20 


where Tyer is the time-out period specified in milliseconds 
and F; jz is the input clock frequency in megahertz. 


A.2 SCSI Control Bus Register (address = 03 
hex) 


EAKSEecSESESSEKE 
sy [et Pat [mao [a seo [oS 


The SCSI Control Bus Register will reflect the state of the 
SCSI bus lines BSY, SEL, MSG, C/D, I/O, and ATN upon 
completion of a low-level SCSI VO command. The bits RAI 
and RAO indicate the state of REQ in and ACK out if the 
AIC-33C93C is in the Connected-as-a-Target state or in the 
~ Connected-as-a-SCAM-device state; otherwise, they indicate 












the state of ACK in and REQ out. If a bit is set, the | 


corresponding SCSI control line is asserted. If a bit is not set, 
the internal microcontroller detected that the corresponding 
SCSI control line was negated, perhaps due to a wired-or 
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New and Modified Register Definitions 


glitch. It is the responsibility of the ‘host processor to 
debounce the signals. 


This register is also used to specify the phase to be set by the 
Set Phase command. 


A.3 SCSI Data Bus Register (address = 04 hex) 


EAKSEsESESESERKD 
07 [308 305 [os | so [502 sor [ oo 


The SCSI Data Bus Register, in most cases, will reflect the 
state of the SCSI data bus upon completion of a low-level 
SCSI /O Command. If a bit is set, the corresponding SCSI 
data bus line is asserted. If a bit is not set, the internal 
microcontroller detected that the corresponding SCSI data 
line was negated, perhaps due to a wired-or glitch. It is the 
responsibility of the host processor to debounce the signals. 






If the Read SCSI Bus command is executed while in the 
Connected-as-an-Initiator state, this register will contain the 
value of the data latched on the last REQ pulse if the phase 
was an in phase. If the previous REQ pulse occurred during 
an out phase, the value returned in this register is 
unpredictable. 





This register is also used to specify the data value to be driven 
onto the SCSI data bus by the AIC-33C93C during the SCAM 
Transfer and Set Data Bus commands. 


B.0 New or Modified Interrupts 


B.1 SCAM Selection Completed, and a SCAM 
Master Responded (12 hex) 


A SCAM Select command completed, and a SCAM master is 
present on the bus. The state of the AIC-33C93C is 
Connected-as-a-SCAM-device. 


_B.2_ SCAM Transfer Cycle Completed Successful- 


Ly (15 hex) 


A SCAM Transfer command completed successfully. The state 
of the AIC-33C93C is Connected-as-a-SCAM-device. 
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New or Modified Commands 


B.3 SCAM Selection Completed, anda SCAM 
Master Did Not Respond (17 hex) 


A SCAM Select command completed, and a SCAM master 
did not 
Disconnected. 


B.4 SCAM Disconnect Has Occurred (45 hex) 


The AIC-33C93C detected the negation of C/D at the 
beginning of a SCAM Transfer command. The state of the 
AIC-33C93C is Disconnected. 


B.5 SCAM Selection Occurred (86 hex) 


The AIC-33C93C responded to a SCAM selection attempt 
and found a SCAM master present. The AIC-33C93C is in the 
Connected-as-a-SCAM-device state. 


C.0 New or Modified Commands 


C.l Reset (00 hex) 


This command functions as before but is now also valid in the 
Connected-as-a-SCAM-device state. 


C.2 Disconnect (04 hex) 


This command functions as before but is now also valid in the 
Connected-as-a-SCAM-device state. 


C.3 Low-Level SCSI I/O Commands 


¢ All low-level SCSI I/O commands implicitly execute a 
Read SCSI Bus command after the specified action is 
performed. 

* Except for the Read SCSI Bus command, the low-level 
commands are valid only in the Connected-as-a-SCAM- 
device state. 


C.3.1 Set Phase (28 hex) 
This command sets the SCSI bus phase pins MSG, C/D, and 


VO as specified by the value in the SCSI Control Bus 
Register. Bits 3 through 7 of the register are ignored by this 
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respond. The state of the AIC-33C93C is. 


SCAM Selection Completed, and a SCAM Master Did Not Respond (17 hex) 


command. No interrupt is generated upon completion of this 
command. 


C.3.2 Set Data (29 hex) 


This command forces the data specified in the SCSI Data Bus 
Register onto the SCSI data bus lines, with the proper parity. 
No interrupt is generated upon completion of this command. 


C.3.3 Read SCSI Bus (2A hex) 


This command returns the state of the SCSI bus control lines 
and the SCSI bus data lines in, respectively, the SCSI Control 
Bus Register and the SCSI Data Bus Register. No interrupt is 
generated upon completion of this command. This command 
is valid in all states. 


C.4 SCAM Support Commands 


C.4.1 Enable SCAM Tolerant Timings (2C hex) 


This command alters two timings involved during the 
reselection and selection phases. First, the AIC-33C93C will 
not respond to a normal SCSI selection or reselection until 
after a valid selection or reselection phase has persisted for 
more than four milliseconds. Second, the AIC-33C93C 
changes its interpretation of the Time-out Period Register so 
that the maximum selection and reselection time-out is four 
milliseconds. These timings are in effect until the AIC- 
33C93C is reset. No interrupt is generated upon completion of 
this command. 


C.4.2. Enable SCAM Selection (2D hex) 


This command enables the AIC-33C93C to respond to a 
SCAM selection. Resetting the device disables the response to 
SCAM selection. No interrupt is generated upon completion 
of this command. 


C.4.3 SCAM Select (2E hex) 


This command causes the AIC-33C93C to perform a SCAM 
selection. The setting the SBT bit determines whether the 
AIC-33C93C behaves as a level 2 SCAM slave device 
(SBT=1) or as a level 1 SCAM master device (SBT=0). 
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SCAM Support Commands 


Upon detecting the bus free condition, the AIC-33C93C will 
arbitrate for the bus. If acting as a SCAM master, it will 
arbitrate with an ID; if acting as a SCAM slave, it will 
arbitrate without an ID. If it loses arbitration, the AIC- 
33C93C will release all SCSI signals and will wait for the bus 
free condition before beginning the process over again. Once 
the AIC-33C93C has won arbitration, it will proceed with 
SCAM selection. 


The length of the SCAM selection phase is determined by the 
value in the Time-out Period register. (With a 20 MHz input 
frequency, the value of the Time-out register equals the 
SCAM selection time in milliseconds.) 


Upon completion of the selection attempt, the AIC-33C93C 
will generate an interrupt. If a SCAM master is present, i.e. 
C/D is asserted, the AIC-33C93C will generate a 12 hex 
interrupt and will be in the Connected-as-a-SCAM-device 
state. Otherwise, the AIC-33C93C will generate a 17 hex 
interrupt and will be in the Disconnected state. 


C.4.4 SCAM Transfer (2F hex) 


This command is valid only in the Connected-as-a-SCAM- 
device state. It causes the AIC-33C93C to perform a SCAM 
transfer cycle. The data to be transferred is specified in the 
SCSI Data Bus Register, and the data latched is returned in 
the SCSI Data Bus Register. For both the data to be sent and 
the latched data, only the five least-significant bits of the 
register are valid. 


The AIC-33C93C samples C/D before performing a transfer, 
and if it detects that C/D has been released, it will terminate 
the command with a SCAM-Disconnect-Occurred interrupt 
(45 hex) and release all SCSI lines. The AIC-33C93C will be 
in the Disconnected state. 


If C/D is asserted, the AIC-33C93C will perform the transfer 
and then generate a Successful-SCAM-Transfer-Cycle 
interrupt (15 hex). The AIC-33C93C will be in the Connected- 
as-a-SCAM-device state. 
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AIC-33C93C Data Sheet 


Level 1 SCAM Master 


D.O Level 1 SCAM Master 


Power-up: 


Bus Reset: 
Int 00 


Select ID State: 
Uncategorized ID 
Int 16 
Int 42 


No uncategorized IDs 


Assign ID State: 


AIC-33C93C Data Sheet 
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SCAM Support Commands 


Bus Reset 


Write Hard ID to Own ID register 

Soft Reset 

Enable SCAM Tolerant Timings 

Categorize IDs using configuration parameters, if any 


Select-and-Transfer 

Target responded; ID in use 

Go to Select ID state 

Target did not respond; ID not in use 
Go to Select ID state 

Go to Assign ID state 


SCAM Select 

SCAM Transfer (as many as needed) 
Disconnect 

Repeat Assign ID state, if necessary 
Soft Reset _ 

Go to Normal Operation 
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SCAM Support Commands Level 1 or 2 SCAM Slave 


E.0 Level 1 or 2 SCAM Slave 


¢ Italicized text applies only to SCAM devices with a default ID. 
¢ Bold text applies only to Level 2 SCAM Slave devices. 


Power-up or Bus Reset: 
Int 00 => Set Own ID to Default ID 
Soft Reset 
Enable SCAM Tolerant Timings 
Enable SCAM Selection 
Enable Reselection 


Monitor State: 

Wait for Select and Receive 

Int 13 = Normal SCSI Selection; ID confirmed 
Process SCSI command 
Soft Reset 
Go to Normal Operation 

Int 80/81 => Reselected; ID confirmed 
Process reselection 
Soft Reset 
Go to Normal Operation 

Int 86 : => SCAM selected 

. Disable response to selection and reselection 

Go to Assignable Transfer state 

Time-out = Time to initiate SCAM selection 
Go to Abort state or Select state 


Abort State: 

Abort Wait-for-Select-and-Receive 

Int 13 => Normal SCSI Selection; ID confirmed 
Process SCSI command 
Soft Reset 
Go to Normal Operation 

Int 22 => Wait-for-Select-and-Receive aborted 
Go to Time-out state 

Int 80/81 => Reselected; ID confirmed 
Process Reselection 
Soft Reset 

ae ae | a - Go to Normal Operation 

Int 86 => SCAM selected 
Disable response to selection and reselection 
Go to Assignable Transfer state 
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Level 1 or 2 SCAM Slave 


Select State: 
Int 12 
Int 17 


Int 80/81 


Int 82/83 


Int 86 


Assignable Wait State: 
Int 86 


Assignable Transfer State: 
Int 15 


ID assigned 


ID not assigned 
Int 45 
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SCAM Support Commands 


SCAM Select 

SCAM master responded 

Go to Assignable Transfer state 

SCAM master did not respond 

Go to Monitor State 

Reselected; ID confirmed 

Process reselection 

Soft Reset 

Go to Normal Operation 

Selected; ID confirmed | 

Resume Wait-for-Select-and-Receive (10) 
Process SCSI command 

Soft Reset 

Go to Normal Operation 

SCAM selected 

Disable response to selection and reselection 
Go to Assignable Transfer state 


SCAM selected 
Go to Assignable Transfer state 


SCAM transfer 

Successful transfer 

Disconnect 

Soft Reset 

Go to Normal Operation 

Go to Assignable Transfer State 
SCAM master ended the connection 
Go to Assignable Wait State 
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